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INTRODUCTION 

Zilog was founded in 1974, and within its first year 
brought td martlet the most popular and best selling 
microprocessor in the world, the Z80 8^blt 
microprocessor. 

With the unparalleled success of the Z80 CPU, the 
name Zitog became synonomous with quality, design 
integrity, and complete company support elements that 
remain integral to Zilog today. 

Headquartered in Campbell, California, Zilog draws 
upon the services and skills of the most talented high 
technology minds in the industry. Zilog's Nampa, Idaho 
manufacturing facility, and assembly plant in the 
Philippines are the best of their size today. They provide 
Zilog customers with a total solution, from engineering, 
to production, to worldwide on-time delivery of the 
growing family of Zilog microprocessor and peripheral 
products. 
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FEATURES 



Complete microcomputer, 2K bytes of ROM, 1 28 bytes of 
RAM, and 22 I/O lines. 

144-byte register file, including 124 general-purpose 
registers, four I/O port registers, and 14 status and 
control registers. 

Vectored, priority interrupts for I/O and counter/timers. 

Two programmable 8-bit counter/timers, each with a 6-bit 
programmable prescaler 



Register Pointer so that short, fast instructions can 
access any one of the nine working register groups. 

On-chip oscillator that accepts crystal or external 
clock drive. 

8 MHz 

Single -i- 5 power supply— all pins TTL-compatible. 

Average instruction execution time of 2.2 \is, 
maximum 1 .5 fxs. 



GENERAL DESCRIPTION 



The Z8600 microcomputer introduces a new level of 
sophistication to single-chip architecture. Compared to 
earlier single-chip microcomputers, the Z8600 offers: 

■ faster execution 

■ more efficient use of memory 

■ more sophisticated interrupt, input/output, and bit 
manipulation capabilities 



■ easier system expansion 

Under program control, the MCU can be tailored to the 
needs of its user It can be configured as a stand-alone 
microcomputer with 2K bytes of internal ROM. In all 
configurations, a large number of pins remain available for 
I/O. 

The MCU is offered in a 28 pin Dual-ln-Line-Package (DIP) 
(Figures 1 and 2). 
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Figure 1 . Pin Functions 



Figure 2. Pin Assignments 



PIN DESCRIPTIONS 



pS. Data Strobe (output, active Low). Data Strobe is 
activated once for each memory transfer. 

POo-P05,P1o-Pl7, P2rP25, P3i, PSs, PSq. I/O Port lines 
(bidirectional, TTL-compatible). These 22 I/O lines are 
grouped in four ports that can be configured under program 
control for I/O. 



RESET. Re set (inp ut, active Low). RESET initializes the 
MCU. When RESET is deactivated, program execution 
begins from internal program location OOOCh^ 

XTAL1, XTAL2. Crystal 1, Crystal 2 (time-base input and 
output). These pins connect a parallel-resonant 8 MHz 
crystal to the on-chip clock oscillator and buffer 



ARCHITECTURE 



The MCU's architecture is characterized by a flexible I/O 
scheme, an efficient register and address space structure, 
and a number of ancillary features that are helpful in many, 
applications. (Figure 3). 

Microcomputer applications demand powerful I/O 
capabilities. The MCU fulfills this with 22 pins dedicated to 
input and output. These lines are grouped in four ports and 
are configurable under software control to provide timing, 
status signals, and parallel I/O. 



Two basic internal address spaces are available to support 
this wide range of configurations: program memory and the 
register file. The 144-byte random-access register file is 
composed of 124 general-purpose registers, four I/O port 
registers, and 14 control and status registers. 

To unburden the program from coping with real-time 
problems such as counting/timing, two counter/timers with 
a large number of user-selectable modes are offered 
on-chip. 
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ADDRESS SPACES 



Program Memory. The 16-bit program counter addresses 
2K bytes of program memory space as shown in Figure 4. 

The first 12 bytes of program memory are reserved for the 
interrupt vectors. These locations contain three 16-bit 
vectors that correspond to the three available interrupts. 

Register File. The 144-byte register file includes four I/O 
port registers (R0-R3). 124 general-purpose registers 
(R4-R127) and 14 control and status registers (R241-R255)- 
These registers are assigned the address locations shown in 
Figure 5. 



Instructions can access registers directly or indirectly with 
an 8-bit address field. The MCU also allows short 4-bit 
register addressing using the Register Pointer (one of the 
control registers). In the 4-bit mode, the register file is 
divided into nine working-register groups, each occupying 
16 contiguous locations (Figure 6). The Register Pointer 
addresses the starting location of the active working-register 
group. 

Stacl(s. An 8-bit Stack Pointer (R255) is used for the internal 
stack that resides within the 124 general-purpose registers 
(R4-Ri27)- 
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Figure 4. Program Memory Map 



LOCATION 
255 
254 
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Figure 5. Register File 



Figure 6. Register Pointer 



COUNTER/TIMERS 



The MCU contains two 8-bit programmable counter/timers 
(To and T-i), each driven by its own 6-bit programmable 
prescaler The T-i prescaler can be driven by internal or 
external clock sources; however, the Tq prescaler is driven 
by the internal clock only. 

The 6-bit prescalers can divide the input frequency of the 
clock source by any number from 1 to 64. Each prescaler 
drives its counter, which decrements the value (1 to 256) that 
has been loaded into the counter When the counter reaches 
the end of count, a timer interrupt request— IRQ4 (Tq) or 
IRQ5 (Ti)— is generated. 

The counters can be started, stopped, restarted to continue, 
or restarted from the initial value. The counters can also be 
programmed to stop upon reaching zero (single-pass 



mode) or to automatically reload the initial value and 
continue counting (modulo-n continuous mode)^ The 
counters, but not the prescalers, can be read any time 
without disturbing their value or count mode. 

The clock source for Ti is user-definable and can be the 
internal microprocessor clock (4 MHz maximum) divided by 
four, or an external signal input via Port 3. The Timer Mode 
register configures the external timer input as an external 
clock (1 MHz maximum), a trigger input that can be 
retriggerable or non-retriggerable, or as a gate input for the 
internal clock. The counter/timers can be programmably 
cascaded by connecting the Tq output to the input of Ti. 
Port 3 line P3q also serves as a timer output (Tqut) through 
which To, Ti or the internal clock can be output. 



I/O PORTS 



The MCU has 22 lines dedicated to input and output 
grouped in four ports. Under software control, the ports can 
be programmed to provide address outputs, timing, status 
signals, and parallel I/O. All ports have active pull-ups and 
pull-downs compatible with TTL loads. 

Port can be programmed as an I/O port. 

Port 1 can be programmed as a byte I/O port. 



Port 2 can be programmed independently as input or 
output and is always available for I/O operations. In addition. 
Port 2 can be configured to provide open-drain outputs. 

Port 3 can be configured as I/O or control lines. P3i is a 
general purpose input or can be used for an external 
interrupt request signal (IRQ2)- PSs and P36 are general 
purpose outputs. P36 is also used for timer input (Tin) and 
output (Tout) signals. 



INTERRUPTS 



The MCU allows three different interrupts from three 
sources, the Port 3 line P3i and the two counter/timers. 
These interrupts are both maskable and prioritized. The 
Interrupt Mask register globally or individually enables or 
disables the three interrupt requests. When more than one 
interrupt is pending, priorities are resolved by a 
programmable priority encoder that is controlled by the 
Interrupt Priority register 

All interrupts are vec'tored. When an interrupt request is 
granted, an interrupt machine cycle is entered. This disables 



all subsequent interrupts, saves the Program Counter and 
status flags, and branches to the program memory vector 
locations reserved for that interrupt. This memory location 
and the next byte contain the 1 6-bit address of the interrupt 
service routine for that particular interrupt request. 

Polled interrupt systems are also supported. To accom- 
modate a polled structure, any or all of the interrupt inputs 
can be masked and the Interrupt Request register polled to 
determine which of the interrupt requests needs service. 



CLOCK 



The on-chip oscillator has a high-gain parallel-resonant 
amplifier for connection to a crystal or to any suitable 
external clock source (XTAL1 = Input, XTAL2 = Output). 

Crystal source is connected across XTAL1 and XTAL2 using 
the recommended capacitors (C1. < 1 5 pf) from each pin to 
ground. The specifications are as follows: 



AT cut, parallel resonant 
Fundamental type, 8 MHz maximum 
Series resistance, Rs< 10012 



INSTRUCTION SET NOTATION 



Addressing Modes. The following notation is used to 
describe the addressing nnodes and instruction operations 
as shown in the instruction summary. 

IRR Indirect register pair or indirect working-register 

pair address 

Irr indirect working-register pair only 

X Indexed address 

DA Direct address 

RA Relative address 

IM Immediate 

R Register or working-register address 

r Working-register address only 

IR Indirect-register or indirect working-register 

address 

Ir Indirect working-register address only 

RR Register pair or working register pair address 

Symbols. The following symbols are used in describing the 
instruction set. 

dst Destination location or contents 

src Source location or contents 

cc Condition code (see list) 

@ Indirect address prefix 

SP Stack pointer (control registers 254-255) 

PC Program counter 

FLAGS Flag register (control register 252) 

RP Register pointer (control register 253) 

IMR Interrupt mask register (control register 251) 



Assignment of a value is indicated by the symbol "*-". 
example, 

dst ^ dst -I- src 



For 



indicates that the source data is added to the destination 
data and the result is stored in the destination location. The 
notation "addr(n)" is used to refer to bit "n" of a given 
location. For example, 

dst (7) 

refers to bit 7 of the destination operand. 

Flags. Control Register R252 contains the following six 
flags: 



C 

z 
s 

V 
D 
H 



Carry flag 
Zero flag 
Sign flag 
Overflow flag 
Decimal-adjust flag 
Half-carry flag 



Affected flags are indicated by: 

Cleared to zero 

1 Set to one 

* Set or cleared according to operation 

— Unaffected 

X Undefined 



CONDITION CODES 



Value 


Mnemonic 


Meaning 


Flags Set 


1000 




Always true 


— 


0111 


c 


Carry 


C = 1 


1111 


NO 


No carry 


= 


0110 


z 


Zero 


Z = 1 


1110 


NZ 


Not zero 


Z = 


1101 


PL 


Plus 


8 = 


0101 


Ml 


Minus 


S = 1 


0100 


OV 


Overflow 


V = 1 


1100 


NOV 


No overflow 


V = 


0110 


EQ 


Equal 


Z = 1 


1110 


NE 


Not equal 


Z = 


1001 


GE 


Greater than or equal 


(8 XOR V) = 


0001 


LT 


Less than 


(8 XOR V) = 1 


1010 


. GT 


greater than 


[ZOR(8XORV)] = 


0010 


LE 


Less than or equal 


[ZOR(SXORV)] = 1 


1111 


UGE 


Unsigned greater than or equal 


= 


0111 


ULT 


Unsigned less than 


= 1 


1011 


UGT 


Unsigned greater than 


(0 = OANDZ = 0) = 1 


0011 


ULE 


Unsigned less than or equal 


(00RZ) = 1 


0000 




Never true 





INSTRUCTION FORMATS 



I dst I OPC I 



CCF, Dl, El, IRET, NOP, 
RCF, RET, SCF 



One-Byte Instructions 



OPC i MODJ" 



CLR, CPL, DA, DEC, 

OR ll 1 1 oldst/src I °^CW, INC, INCW, POP, 
OR |1 1 1 0|dst/src I p^^^ PL, RLC. RR, 



OR |l 1 1 0| dst I 



RRC, SRA, SWAP 
JP, CALL (Indirect) 



OPC 


MODE 


dst 


src 



ADC, ADD, AND, 
CP, OR, SBC, SUB, 
TCM, TM, XOR 



MODE 


OPC 


dst/src 


src/dst 



OPC I mode" 



1110 


src 


1110 


dst 



ADC, add, and, CP, 
LD, or, SBC, SUB, 
TCM, TM, XOR 



ADC, ADD, AND, CP, 
OR |i 1 1 ol dst I LD, OR, SBC, SUB, 



1110 


src 


1110 


dst 



MODE 


OPC 


dst/src 


X 


ADDRESS 1 



dst/src OPC 



dst I OPc" 



dst/CC I OPc" 



OR |l 1 1 0| src I 



Two-Byte Instructions 



Three-Byte Instructions 



Figure 7. Instruction Formats 



INSTRUCTION SUMMARY 



Instruction 
and Operation 




AddrMode 
dst src 


Opcode 
Byte 
(Hex) 


Flags Affected 
C Z S V D H 


ADCdst.srq 

dst *- dst + src + 


C 


(Note 1) 


in 


•k -k it "k It 


ADD dst, src 
dst -^ dst + src 




(Note1) 


on 


* * * * * 


AND dst, src 
dst*- dst AND src 




(Note1) 


5n 


- * * 


CALLdst 

SP *- SP - 2 
@SP^PC;PC^ 


dsl 


DA 
IRR 


D6 
D4 




CCF 

C-NOTC 






EF 


* 


CLR dst 

dst ^ 




R 
IR 


BO 
B1 





COM dst 

dst ^ NOT dst 



R 
IR 



60 
61 



— * * 



Instruction 
and Operation 


AddrMode 


Opcode 
Byte 
(Hex) 


Flags Affected 


dst 


src 


C Z S V D H 


CP dst,src , 
dst - src 


(Note1) 


AD . 


* * * * 


DA dst 

dst ^ DA dst 


R 
IR 




40 
41 


* * * X 


DEC dst 
dst *- dst - 1 


R 

IR 




00 
01 


— * * * 


DECWdst 

dst^dst- 1 


RR 
IR 




80 
81 


— * * * 


Dl 

IMR(7)*-0 






8F 





DJNZ r.dst RA 


rA 


r*-r - 1 


r = - F 


ifr#0 




PC *- PC + dst 




Range: +127,-128 





INSTRUCTION SUMMARY (Continued) 



Instruction 
and Operation 


AddrlVlode Opcode 


Flags Affected 


Byte 
dst src (Hex) 


C Z S V D H 


El 

IMR(7)*-1 


9F 





INC dst 


r 


rE — * * * 


dst^dst+ 1 




r = 0- F 




R 


20 




IR 


21 



INCWdst 

dst^dst + 1 



RR 
IR 



AO 
A1 



* * * 



IRET 

FLAGS ^@SP;SP*-SP + 1 
PC ^ @SP; SP *- SP + 2; IMR (7) 



BF * it * it it it 



^1 



JP cc.dst 
if cc is true 
PC ^ dst 



JR cc.dst 
if cc is true, 

PC ^ PC + dst 
Range: +127,-128 



LD dst, src 
dst *- src 



DA cD 

c = 0- F 
IRR 30 

RA cB 

c = 0- F 

r Im rC 

r R r8 

R r r9 

r = - F 

r X C7 

X r D7 

r Ir E3 

Ir r F3 

R R E4 

R IR E5 

R IM E6 

IR IM E7 

IR R F5 



LDC dst, src 
dst ^ src 


r 
Irr 


Irr 
r 


pp 




D2 




LDCI dst, src 

dst^ src 

r ^ r + 1 ; rr *- rr + 1 


Ir 
Irr 


Irr 
Ir 


c^ 




D3 




NOP 






pp 








OR dst, src 

dst *- dst OR src 


(Note 


J1) 


4n _ * * - 


- — 


POP dst 

dst^@SP; 
SP^SP + 1 




R 
IR 


RO 








PUSH src 

SP^SP - 1;@SP^ 


src 


R 
IR 


70 




71 




RCF 

C^O 






CF 


— 



RET 

PC- 



AF 





AddrMode 


Opcode 
Byte 
(Hex) 


Flags Affected 


Instruction 
and Operation 


dst src 


C Z S V D H 






90 
91 




RL dsl 1 


^,5 


it * it it 


jchHz c 








... jm. 


- 


10 
11 




RLC dst 1 


-^ 1 ^ 


* * * * 


^-EHEZ 


3J1R 




nr% 1 




EO 
El 




RR dst 1 1 


3^IR 


* * * * 


L|c| 1h7 












CO 
CI 




RnC dst 1 


3^IR 


* * * * 


SBCdst,src (Notel) 
dst - dst ^ src ^C 


3n 


* * * * 1 * 


SCF 

C^l 




DF 


1 






DO 
D1 




^''^^^•LHHn- 


^,s 


* * * 


1 ♦ ♦ 


IN 




SRP src 

RP *- src 


Im 


31' 




SUBdstsrc 
dst *- dst *- src 


(Notel) 


20 


* * * * 1 * 


SWAP dst rr- 


n J ID 


FO 
F1 


X * * X 


i 


i IR 




TCIVI dst.src 
(NOT dst) AND src 


(Notel) 


en 


- * * 


TM dst, src 
dst AND src 


(Notel) 


in 


- * * 


XORdst.src 

dst *- dst XOR src 


(Notel) 


BD 


- * * 



NOTE 1 : These instructions have an identical set of addressing modes, 

which are encoded for brevity. The first opcode nibble is found in 
the instruction set table above. The second nibble is expressed 
symbolically by a D in this table, and its value is found in tine 
following table to the right of the applicable addressing mode 
pair. 

For example, the opcode of an ADC instruction using the 
addressing modes r (destination) and Ir (source) is 13. 



Addr Mode 



dst 



Lower 
Opcode Nibble 



r 
r 

R 
R 
R 
IR 



r 
Ir 
R 
IR 
IM 
IM 



H 
0, 



SP^SP+2 



REGISTERS (Continued) 



R248P01M 
PORT AND 1 MODE REGISTER 

(F8h; Write Only) 



PO4-PO5 MODE 
OUTPUT = 00 
INPUT = 01 



'7|D6|D5|D4 



3Hi 



PO0-PO3 MODE 
00 = OUTPUT 
01= INPUT 



PI0-PI7MODE 
_ 00 = BYTE OUTPUT 
01 = BYTE INPUT 
11 = HIGH-IMPEDANCE D 



R252 FLAGS 
FLAG REGISTER 

(FCh; Read/Write) 

{d,|d6[d5|d«[d3|D;|d, Idq'I 



^: 



US^R FLAG F1 

USER FLAG F2 
-HALF CARRY FLAG 
■^DECIMAL ADJUST FLAG 
-OVERFLOW FLAG 
-SIGN FLAG 
-ZERO FLAG 
-CARRY FLAG 



R249 IPR 
INTERRUPT PRIORITY REGISTER 

(F9h; Write Only) 



•|D,|D,|D,|D, 


D3JD2|D,|Do| 










RESERVED ' 










INTERRUPT GROUP PRIORITY 
RESERVED = 000 
452 = 001 










542 = 011 
245 = 100 






425 = 101 
254 = 110 
RESERVED = 111 



R253 RP 
REGISTER POINTER 

(FDh; Read/Write) 

I D7 J De I D5 I D4 I D3 I Dj I D, I Do J 



l:::^ 



R250 IRQ 
INTERRUPT REQUEST REGISTER 

(FAh; Read/Write) 



I D, I Ds I D5 I D, I D3 I D^ I D, I Dp I 

oZr — C= 



IRQ2 = P3i INPUT (Da = IRQ5) 
IR04 = To 
IR05 = Ti 



R255SPL 
STACK POINTER 

(FFh; Read/Write) 

|d,|d6|d5|d4|d3|d;|d,[do| 



STACK POINTER LOWER 
" BYTE (SP0-SP7) 



R251 IMR 
INTERRUPT MASK REGISTER 

(FBh; Read/Write) 



I 1 ENABLES IRQ0-IRQ5 

(Do = IRQO) 

RESERVED 



- 1 ENABLES INTERRUPTS 



Figure 8. Control Registers (Continued) 



OPCODE MAP 



Lower Nibble (Hex) 



^ 7 

0) 

1 
z 



6.5 


6.5 


6.5 


6.5 


10,5 


105 


10.5 


105 


6,5 


65 


12/105 


12/100 


65 


12/100 


65 




DEC 


DEC 


ADD 


ADD 


ADD 


ADD 


ADD 


ADD 


LD 


LD 


DJNZ 


JR 


LD 


JP 


INC 




Ri 


iRi 


n r2 


ri.lr2 


R2.R1 


IR2.R1 


R1.IM 


IR1.IM 


n R2 


r2.Ri 


ri RA 


ccRA 


r, IM 


ccDA 


ri 




6,5 


6.5 


65 


6.5 


10.5 


10.5 


10.5 


10.5 
































RLC 


RLC 


ADC 


ADC 


ADC 


ADC 


ADC 


ADC 
































Ri 


IRi 


ri,r2 


{^M2 


R2.R1 


IR2.R1 


Rl IM 


IRl.lM 
































65 


6,5 


6,5 > 


6,5 


10,5 


10,5 


10,5 


10,5 




INC 


INC 


SUB 


SUB 


SUB 


SUB 


SUB 


SUB 
































Ri 


IRi 


ri,r2 . 


ri.li'2 


R2.R1 


IR2,Ri 


Rl.lM 


IRl.lM 
































8,0 


6,1 


6,5 


6,5 


10,5 


10,5 


10.5 


10.5 




JP 


SRP 


SBC 


SBC 


SBC 


SBC 


SBC 


SBC 
































IRRl 


IM 


ri,r2 


ri,lr2 


R2.R1 


IR2,Ri 


Rl,IM 


IRl,IM 
































8.5 


8,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 




DA 


DA 


OR 


OR 


OR 


OR 


OR 


OR 
































Ri 


IRi 


ri,r2 


ri,lr2 


R2.R1 


IR2,Ri 


Rl,IM 


IRl.lM 
































10.5 


10,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 




POP 


POP 


AND 


AND 


AND 


AND 


AND 


AND 
































Ri 


IRi 


ri,r2 


ri.Irs 


R2.R1 


IR2.R1 


R1.IM 


IRl.lM 
































6,5 


6,5 


6,5 


6,5 


10,5 


10,5 


10.5 


10,5 




COM 


COM 


TCM 


TCM 


TCM 


TCM 


TCM 


TCM 
































Ri 


iRi 


ri,r2 


n.irs 


R2.R1 


IR2.R1 


R1.IM 


IRl,IM 
































10/12,1 


12/14,1 


6,5 


6,5 


10,5 


10,5 


10.5 


10,5 




PUSH 


PUSH 


TM 


TM 


TM 


TM 


TM 


TM 
































R2 


IR2 


ri,r2 ' 


ri,lr2 


R2.R1 


IR2.R1 


R1.IM 


IRl.lM 
































10,5 


10,5 














61 


DECW 


DECW 










































Dl 


RRl 


IRi 












































6.5 


6,5 














6.1 


RL 


RL 










































El 


Ri 


IRi 












































10,5 


10,5 


6.5 


6,5 


10,5 


10,5 


10.5 


10.5 


14.0 


INCW 


INCW 


CP 


CP 


CP 


CP 


CP 


CP 






























RET 


RRl 


IRi 


ri.r2 


ri.lr2 


R2.R1 


IR2,Ri 


Rl IM 


IR1.IM 
































6,5 


6,5 


6.5 


6.5 


10,5 


10,5 


105 


10.5 


160 


CLR 


CLR 


XOR 


XOR 


XOR 


XOR 


XOR 


XOR 






























IRET 


Ri 


IRi 


ri.r2 


ri.lr2 


R2.R1 


IR2.R1 


R^.IM 


IRl.lM 
































6,5 


6,5 


12,0 


18,0 








10,5 


' 6.5 


RRC 


RRC 


LDC 


LDCI 








LD 






























RCF 


Ri 


IRi 


ri,lrr2 


Iri,lrr2 








ri,x.R2 
































6.5 


6,5 


12,0 


18,0 


20,0 




20.0 


10,5 . 


65 


SRA 


SRA 


LDC 


LDCI 


CALL* 




CALL 


LD 






























SCF 


Ri 


IRi 


r2,irri 


Ir2,lrri 


IRRl 




DA 


•rg.x.Ri 
































6.5 


6,5 




6,5 


10,5 


10,5 


10.5 


10,5 
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RR 


RR 




LD 


LD 


LD 


LD 


LD 






























CCF 


Ri 


IR1 




ri.lR2 


R2.R1 


IR2.R1 


R1.IM 


IRl.lM 
































85 


8,5 




6,5 




10.5 






60 


SWAP 


SWAP 




LD 




LD 


































NOP 


Ri 


IRi 




Iri,r2 




R2.IR1 






\ 


f 


^ 


' 


} 


t 


) 


r 


\ 


f 


} 


r 


\ 


f 





LOWER 
OPCODE 
NIBBLE 



Bytes per Instruction 



EXECUTION 
CYCLES 



W 



PIPELINE 
CYCLES 



UPPER 

OPCODE ► A 

NIBBLE 



10,5 
CP 

R2.R1 



FIRST, 
OPERAND 



A^ 



SECOND 
OPERAND 



Legend: 

R = 8-bit address 
r = 4-bit address 
Ri orr-i = Dst address 
R2 or r2 = Src address 

Sequence: 

Opcode, First Operand, Second Operand 

NOTE- The blank areas are not defined 



*2-byte instruction, fetch cycle appears as a 3-byte instruction 



REGISTERS 



R241TMR 
TIMER MODE REGISTER 

(F1h; Read/Write) 



R245 PREO 
PRESCALER REGISTER 

(F5h; Write Only) 



Tout MODES 

NOT USED = 00 

To OUT = 01 

Ti OUT = 10 

INTERNAL CLOCK OUT = 11 

T,N MODES 

EXTERNAL CLOCK INPUT = 00 

GATE INPUT = 01 

TRIGGER INPUT = 10 

(NON-RETRIGGERABLE) 

TRIGGER INPUT = 11 
(RETRIGGERABLE) 



F' 


Ob\Ds 


d,|d3[Dj|d, |Do| 








L 



l°-l°«l° 



D4 I D3 [ Dz I D, I Dp I 



LCOl 




COUNT MODE 

To SINGLE-PASS 
1 = To MODULO-N 



PRESCALER MODULO 
-(RANGE: 1-64 DECIMAL 
01-00 HEX) 



R242 T1 
COUNTER TIMER 1 REGISTER 

(F2h; Read/Write) 

I D7 I De j Ds [ D4 [ D3 j D; ( D, I Do I 



R246P2M 
PORT 2 MODE REGISTER 

(F6h; Write Only) 

(071061051041031021011071 



Ti INITIAL VALUE (WHEN WRITTEN) 

-(RANGE 1 256 DECIMAL 01 00 HEX) 

T, CURRENT VALUE (WHEN READ) 



P21-P25 DEFINITION 
- DEFINES BIT AS OUTPUT 
1 DEFINES BIT AS INPUT 



R243 PRE1 
PRESCALER 1 REGISTER 

(F3h; Write Only) 



R247P3M 
PORT 3 MODE REGISTER 

(F7h;/ Write Only) 



I D7 I De I Ds I D4 I Da I D; I D, I Dp I 



iDylOslOslo, 



COUNT MODE 
- = T, SINGLE-PASS 
1 = T, MODULO-N 
CLOCK SOUhCE ' 
_ 1 = T, INTERNAL 

= T, EXTERNAL TIMING INPUT 
(Tin) mode 

PRESCALER MODULO 
-(RANGE: 1-64 DECIMAL 
01-00 HEX) 



O3ID2IDJD0I 



L. 



- RESERVED 

- RESERVED 

- RESERVED 

- P31 = INPUT (T,n) P36 = OUTPUT (Tqut) 

- RESERVED 



R244 TO 
COUNTER/TIMER REGISTER 

(F4h; Read/Write) 

} D7|D6[D5|D4[D3[D;|D) [DoJ 



To INITIAL VALUE (WHEN WRITTEN) 

-(RANGE: 1 256 DECIMAL 01 00 HEX) 

To CURRENT VALUE (WHEN READ) 



Figure 8. Control Registers 
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-®- 



-^k© —Tk® V<3>-4 



-<3>-^ 



Tin 



iRQn 




Figure 9. Timing 



AC CHARACTERISTICS 

Timing Table 



Number Symbol 



Parameter 



Z8600 

IVIin l\Aax 



Notes* 



1 


TpC 


input Clock Period 


125 


1000 


2 


TrCJfC 


Clock Input Rise and Fall Times 




25 


3 


TwC 


Input Clock Width 


37 




4 


TwTinL 


Tinner Input Low Width 


100 




5 


TwTinH 


Timer Input High Width 


3TpC 




6 


TpTin 


Timer Input Period 


8TpC 




7 


TrTln.TfTin 


, Timer Input Rise a'nd Fall Times 




100 


8 


TwIL 


Interrupt Request Input Low Time 


100 




9 


TwIH 


Interrupt Request Input High Time 


3TpC 





2 

2 

2,3 
2.3 



NOTES: 

1 . Clock timing references use 3.8V for a logic " 1 " and 0.8V for a logic "0". 

2. Timing references use 2.0V for a logic "1" and 0.8V for a logic "0". 

3. Interrupt request via Port 3 (P3i-P33). 
* Units in nanoseconds (ns). » 
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ABSOLUTE MAXIMUM RATINGS 

Voltages on all pins with respect 

toGND -0.3V to +7.0V 

Operating Ambient 

Temperature See Ordering Information 

Storage Temperature -65°Cto +150°C 

STANDARD TEST CONDITIONS 

The DC characteristics listed below apply for the following 
standard test conditions, unless otherwise noted. All 
voltages are referenced to GND. Positive current flows into 
the referenced pin. 

Standard conditions are: 

■ + 4.75V <Vcc< + 5.25V 

■ GND = OV 

■ 0°C<Ta< +70°C 

DC CHARACTERISTICS 



Stresses greater than those listed under Absolute Maximum Ratings may 
cause permanent damage to the device. This is a stress rating only; 
operation of the device at any condition above those indicated in the 
operational sections of these specifications is not implied. Exposure to 
absolute maximum rating conditions for extended periods may affect 
device reliability. 



FROM OUTPUT , 
UNDER TEST ^ 



150pF?t 



Figure 10. Test Load1 




Symbol 


Parameter 


l\Ain 


IVIax 


Unit 


Condition 


VCH 


Clock Input High Voltage 


3.8 


Vcc 


V 


Driven by External Clock Generator 


VCL 


Clock Input Low Voltage 


-0.3 


0.8 


V 


Driven by External Clock Generator 


V|H 


Input High Voltage 


2.0 


Vcc 


V 




V|L 


Input Low Voltage 


-0.3 


0.8 


V 




Vrh 


Reset Input High Voltage 


3.8 


Vcc 


V 




Vrl 


Reset Input Low Voltage 


-0.3 


0.8 


V 




VOH 


Output High Voltage 


■ 2.4 




V 


l0H= -250 /.A 


Vol 


Output Low Voltage 




0.4 


. V 


lOL = +2.0nnA 


l|L 


Input Leakage 


-10 


10 


mA 


OV<V|N<+ 5.25V 


'oh 


Output Drive Current 




1.5 


mA 


VoH = +2.4V 








2.50 


HA 


VoH = +^0V 


lOL 


Output Leakage 


-10 


10 


ptA 


OV<V|N< + 5.25V 


l|R 


Reset Input Current, 




-50 


mA 


Vcc = + 5.25V Vrl = OV 


'Ice 


Vcc Supply Current 




150 


nnA 
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Product Specification 



June 1987 



Z8601/Z8603 
Z8611/Z8613 Z8® 



Z8601 Single-Chip MCU with 2K ROM 

Z8603 Prototyping Device with 2K EPROM Interface 

Z8611 Single-Chip MCU with 4K ROM 

Z8613 Prototyping Device with 4K EPROM Interface 



Features ■ Complete microcomputer, 2K (8601) or 4K 

(8611) bytes of ROM, 128 bytes of RAM, 32 
I/O lines, and up to 62K (8601) or 60K (8611) 
bytes addressable external space each for 
program and data memory. 

■ 144-byte register file, including 124 general- 
purpose registers, four I/O port registers, 
and 16 status and control registers. 

■ Average instruction execution time of 1 .5 pis, 
maximum of 1 /as. 

■ Vectored, priority interrupts for I/O, 
counter/timers, and UART. 



Full-duplex UART and two programmable 
8-bit counter/timers, each with a 6-bit 
programmable prescaler. 

Register Pointer so that short, fast instruc- 
tions can access any of nine working register 
groups in 1 /IS. ^ 

On-chip oscillator which accepts crystal or 
external clock drive. 



Single + 5 V power supply — all pin^ TTL 
compatible. 

12.5 MHz. 



General The Z8 microcomputer introduces a new level 

Description of sophistication to single-chip architecture. 
Compared to earlier single-chip micro- 
computers, the Z8 offers faster execution; more 
efficient use of memory; more sophisticated 
interrupt, input/output and bit-manipulation 
capabilities; and easier system expansion. 

Under program control, the Z8 can be tailored 
to the needs of its user. It can be configured as a 



stand-alone microcomputer with 2K or 4K bytes 
of internal ROM, a traditional microprocessor 
that manages up to 124K bytes of external 
memory, or a parallel-processing element in a 
system with other processors and peripheral 
controllers linked by the Z-BUS® bus. In all 
configurations, a large number of pins remain 
available for I/O. 







RESET +5V 
R/W GND 
DS XTAL1 
AS XTAL2 
POo P2o 
POi P2i 

PO2 P22 
PO3 P23 

PO4 P24 

PO5 Z8601I11 ^^^ 
POe MCU P26 

PO7 P2r 
PI0 P3o 
PI1 P3i 
PI2 P32 
PI3 P33 
PI4 P34 
PI5 P35 
Pie P36 
PI7 P37 




TIMING 






AND 
CONTROL 




























PORTO 


— 


* 




* 


I/O OR A8-A15 










^ 










* 


, 








PORT1 






PROGRAMMABLE) 




I/O OR AD0-AD7 








* 















PORT 2 

(BIT PRO- 
GRAMMABLE)^ 



PORTS 

SERIAL AND 
PARALLEL I/O 
AND CONTROL 





Ky 






+5V r 


1 ^^ 


40 


JP3. 


XTAL2 C 


2 


39 


]P3, 


XTAL1 C 


3 


38 


3«, 


P3.C 


4 


37 


]P2. 


P3oi: 


5 


36 


]P2. 




6 


35 


3p2. 


R/W C 


7 


34 


3«3 


D-SC 


8 


33 


]P2. 


A-SC 


9 


32 


3p2. 


PSsC 


10 Z8601/11 


31 


]P2o 


GND C 


11 •-«" 


30 


3P33 


PhL 


12 


29 


1P^. 


POoC 


13 


28 


1", 


POiC 


14 


27 


3". 


PCC 


15 


26 


Dpn 


PO3L 


16 


25 


]pi. 


P04 c 


17 


24 


]P13 


P05 c 


18 


23 


]P1, 


POeC 


19 


22 


]P1- 


P0.L: 


20 


21 


DP1. 



Figure 2a. 40-pin Dual-In-Line Package (DIP), 
Pin Assignments 
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Pin AS. Address Strobe (output, acti^ve Low). 

Description Address Strobe is pulsed once at the begin- 
ning of each machine cycle. Addresses output 
via Port 1 for all external program or data 
, memory transfers are valid at the trailing edge 
of AS. Under program control, AS can be 
placed in the high -impedance state along with 
Ports and 1, Data Strobe and Read/Write. 

DS. Data Strobe (output, active Low). Data 
Strobe is activated once for each external 
memory transfer. 

PO0-PQ7, Plo-Pl?' P2o-P27. P3o-P37. I/O Port 
Lines (input /outputs, TTL-compiatible). These 
32 lines are divided into four 8-bit I/O ports 
that can be configured under program control 
for I/O or external memory interface. 



RESET. Reset (input, active L ow). RESET ini- 
tializes the Z8. When RESET is deactivated. 



program exeicution begins from internal 
prograrn location OOOCh- 

ROMIess. (input, active LOW). This pin is only 
available on the 44 pin version of the Z861 1 . 
When connected to GND disables the internal 
ROM and forces the part to function as a Z8681 
ROMIess Z8. When left unconnected or pulled 
high to V^jjjthe part will function normally as a 
Z8611. 

R/ W. Bead /Write (output). R/W is Low when 
the Z8 is writing to external program or data 
memory. 

XTAL1,XTAL2. Crystall Crystal 2 {iime-base 
input and output). These pins connect a parallel 
resonant 12.5 MHz crystal or an external single- 
phase 12.5 MHz clock to the on-chip clock 
oscillator and buffer. 



^ ^'b^^'b'^^^^^^ ^'b\'b^^«v\^«>^«v^ 





^ 6 


5 4 3 2 1 44 43 42 41 40 \^ 










39 
38 


NC 


R/W 




P24 


DS 






37 


P23 


AS 


10 




36 


P22 


P35 
GND 
P32 


11 
12 
13 


Z8611 
MCU 


35 
34 
33 


P2i 
P2o 
P33 


POo 


14 




32 


P34 


PO1 


15 




31 


Pl7 


PO2 


16 
17 




30 
29 


P16 


ROMIess 




His 




\J£ 


19 20 21 22 23 24 25 26 27 2 


l/ 





<j«'%<i%<i^^<i%«>'^^'^'^<j^^<j^VV*''»^ 



Figure 2b. 44-pin Chip Carrier, Pin Assignments 
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Architecture Z8 architecture is characterized by a flexible 

I/O scheme, an efficient register and address 
space structure and a number of ancillary- 
features that are helpful in many applications. 
Microcomputer applications demand power- 
ful I/O capabilities. The Z8 fulfills this with 32 
pins dedicated to input and output. These lines 
are grouped into four ports of eight lines each 
and are configurable under software control to 
provide timing, status signals, serial or parallel 
I/O with or without handshake, and an address/ 
data bus for interfacing external memory. 

Because the multiplexed address/data bus is 
merged with the I/O-oriented ports, the Z8 can 
assume many different memory and I/O con- 
figurations. These configurations range from 
a self-contained microcomputer to a micropro- 
cessor that can address 124K (Z8601) or 120K 
(Z8611) bytes of external memory. 



Three basic address spaces are available to 
support this wide range of configurations: 
program memory (internal and external), data 
memory (external) and the register file (inter- 
nal). The 144-byte random-access register file 
is composed of 124 general-purpose registers, 
four I/O port registers, and 16 control and 
status registers. 

To unburden the program from coping with 
real-time problems such as serial data com- 
munication and counting/timing, an asynchro- 
nous receiver/transmitter (UART) and two 
counter/timers with a large number of userse- 
lectable modes are offered on-chip. Hardware 
support for the UART is minimized because one 
of the on-chip timers supplies the bit rate. 



OUTPUT INPUT 



COUNTER/ 

TIMERS 

(2) 



INTERRUPT 
CONTROL 



i£ 






II 



2E 



^ 



XTAL AS DS R/W RESET 

ti t t t i 



MACHINE TIMING AND 
INSTRUCTION CONTROL 



REGISTER 
POINTER 



REGISTER FILE 
124 X 8-BIT 



XT 



] 



(BIT PROGRAMMABLE) 



ADDRESS OR I/O 
(NIBBLE PROGRAMMABLE) 



S 



^ 



H 



PROGRAM 
MEMORY 



2E 



PROGRAM 
COUNTER 



3T 



Mnr ^^ ^^ 



Z8601 
2048 X 8-BIT 

Z8611 
4096 X 8-BIT 



ADDRESS/DATA OR I/O 
(BYTE PROGRAMMABLE) 



Figure 3. Functional Block Diagram 
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Address Program Memory. The 16-bit program counter 

Spaces addresses 64K bytes of program memory space.. 

Program memory can be located in two areas: 
one internal and the other external (Figure 4). 
The first 2048 (Z8601) or 4096 (Z8611) bytes 
consist of on-chip mask-programmed ROM. At- 
addresses ^048 (Z8601) or 4096 (Z8611).and 
greater, the Z8 executes external program 
memory fetches. 

The first 12 bytes of program memory are 
reserved for the interrupt vectors. These loca- 
tions contain six 16-bit vectors that correspond 
to the six available interrupts. 

Dttta Memory. The Z8 can address 62K (Z8601) 
or 60K (Z8611) bytes of external data memory 
beginning at location 2048 (Z8601) or 4096 
(Z8611) (Figure 5). External data memory may 



be included with or sepa rated from the external 
program memory space. DM, an optional I/O 
function that can be programmed to appear on 
pin P34, is used to distinguish between data and 
program memory space. 

Register File. The 144-byte register file 
includes four I/O port registers (R0-R3), 124 
general-purpose registers (R4-R127) and 16 
control and status registers (R240-R255). These 
registers are assigned the address locations 
shown in Figure 6. 

Z8 instructions can access registers directly 
or indirectly with an 8-bit address field. The Z8 
also allows short 4-bit register addressing using 
the Register Pointer (one of the control regis- 
ters). In the 4-bit mode, the register file is 



65535 

^^ 

Location of 
first byte of 

executed \ 
after reset 12 


EXTERNAL 
ROM OR RAM 


ON-CHIP 
ROM 


>< 


11 


IRQ5 


10 


IRQS 


9 


IRQ4 


8 


IRQ4 


interrupt ^ 


iRQ3 


Vector » 
(Lower Byte) \ 


IRQS 


*< 


pRoa 


interrupt J' 
Vector "^3 


If 


IRQ2 1 


IRQ1 


(Upper Byte) 2 


IRQ1 




IRQO 





IRQO 





EXTERNAL 




DATA 




MEMORY 






zseoi^Jj; 






NOT ADDRESSABLE 



Figure 4. Program Memory Map 



Figure 5. Dato Memory Map 



LOCATION 




IDENTIFIERS 


255 


STACK POINTER (BITS 7-0) 


SPL 


254 


STACK POINTER (BITS 15-8) 


SPH 


253 


REGISTER POINTER 


RP 


252 


PROGRAM CONTROL FLAGS 


FLAGS 


251 


INTERRUPT MASK REGISTER 


IMR 


250 


INTERRUPT REQUEST REGISTER 


IRQ 


249 


INTERRUPT PRIORITY REGISTER 


IPR 


248 


PORTS 0-1 MODE 


P01M 


247 


PORT 3 MODE 


P3M 


246 


PORT 2 MODE 


P2M 


245 


TO PRESCALER 


PREO 


244 


TIMER/COUNTER 


TO 


243 


T1 PRESCALER 


PRE1 


242 


TIMER/COUNTER 1 


T1 


241 


TIMER MODE 


TMR 


240 


SERIAL I/O 


SIO 




NOT 
IMPLEMENTED 




127 
4 


GENERAL-PURPOSE 
REGISTERS 




3 


PORT 3 


P3 


2 


PORT 2 


P2 


1 


PORT 1 


PI 





PORT 


PO 



Tile upper nibble of the register file address 
- provided by the register pointer specifies 
the active wori(ing-register group. 



The lower 
nibble of 
the register 
file address 
- provided by 
the instruction 
points to the 



register. 



Figure 6. The Register File 



Figure 7. The Register Pointer 
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2037-004, 005, 006, 007 



divided into nine working-register groups, each 
occupying 16 continguous locations (Figure 6). 
The Register Pointer addresses the starting 
location of the active working-register group. 

Stacks. Either the internal register file or the 
external data memory can be used for the stack. 



A 16-bit Stack Pointer (R254 and R255) is used for 
the external stack, which can reside anywhere in 
data memory between locations 2048 (8601) or 
4096 (8611) and 65535. An 8-bit Stack Pointer 
(R255) is used for the internal stack that resides 
within the 124 general-purpose registers 
(R4-R127). 



Serial Port 3 lines P3o and PS? can be programmed as 

Input/ serial I/O lines for full-duplex serial asynchro- 

Output nous receiver/transmitter operation. The bit rate 

is controlled by Counter/Timer 0, at 12 MHz. 

The Z8 automatically adds a start bit and two 
stop bits to transmitted data (Figure 8). Odd 
parity is also available as an option. Eight data 
bits are always transmitted, regardless of parity 

Transmitted Data 

(No Parity) 



selection. If parity is enabled, the eighth bit is 
the odd parity bit. An interrupt request (IRQ4) is 
generated on all transmitted characters. 

Received data must have a start bit, eight data 
bits and at least one stop bit. If parity is on, bit 7 
of the received data is replaced by a parity error 
flag. Received characters generate the IRQ3 
interrupt request. 



Received Data 

(No Parity) 



|SP 


sp|o,|d,|o,|d,|d,|o,|d,|o.|8t| 










L 









START BIT 
EIGHT DATA BITS 
TWO STOP BITS 



Transmitted Data 

(With Parity) 



|SP 


sp| p|d,|o,|d,|d,|d,|d,|i),|st| 














L 















-START BIT 
-SEVEN DATA BITS 
-ODD PARITY 
-TWO STOP BITS 



I SP I D7 I Dg I D5 I D4 I D3 I D; I Di I Dp I St"| 

u 



START BIT 
EIGHT DATA BITS 
ONE STOP BIT 



Received Data 

(With Parity) 

|sp|p|d6|d5|d4|d3|d2|d^|do|st| 

L 



START BIT 
SEVEN DATA BITS 
PARITY ERROR FLAG 
ONE STOP BIT 



Figure 8. Serial Data Formats 



Counter/ The Z8 contains two 8-bit programmable 

Timers counter/timers (Tq and Ti), each driven by its 

own 6-bit programmable prescaler. The Ti 
prescaler can be driven by internal or external 
clock sources; however, the Tq prescaler is 
driven by the internal clock only. 

The 6-bit prescalers can divide the input fre- 
quency of the clock source by any number from 
1 to 64. Each prescaler drives its counter, which 
decrements the value ( 1 to 256) that has been 
loaded into the counter. When the counter 
reaches the end of count, a timer interrupt 
request — IRQ4 (to) or IRQ5 (Ti) — is generated. 

The counters can be started, stopped, 
restarted to continue, or restarted from the ' 
initial value. The counters can also be pro- 
grammed to stop upon reaching zero (single- 



pass mode) or to automatically reload the initial 
value and continue counting (modulo-n contin- 
uous mode). The counters, but not the presca- 
lers, can be read any time without disturbing 
their value or count mode. 

The clock source for Ti is user-definable and 
can be the internal microprocessor clock 
divided by four, or an external signal input via 
Port 3. The Timer Mode register configures the 
external timer input as an external clock, a 
trigger input that can be retriggerable or non- 
retriggerable, or as a gate input fof the internal 
clock. The counter/timers can be programmably 
cascaded by connecting the Tq output to the 
input of Tj. Port 3 line P36 also serves as a timer 
output (Tout) through which Tq, Ti or the inter- 
nal clock can be output. 
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I/O Ports The Z8 has 32 lines dedicated to input and 

output. These lines are grouped into four ports of , 
eight lines each and are configurable as input, 
output or address/data. Under software control, 
the ports can be programmed to provide address 



outputs, timing, status sig;nals, serial I/O, and 
parallel I/O with or without handshake. All ports 
have active pull-ups and pull-downs compatible 
with TTL loads. 



Port 1 can be programmed as a byte I/O port 
or as an address/data port for interfacing 
external memory. When used as an I/O port. Port 
1 may be placed under handshake con- 
trol. In this configuration, Port 3 lines P33 and 
P34 are u sed as the handshake controls RDYj 
and DAVi (Ready and Data Available) . 

Memory, locations greater than 2048 (Z8601) or 
4096 (Z8611) are referenced through Port 1 . To 
interface external memory, Port 1 must be 
programmed for the multiplexed Address/Data 
mode. If more than 256 external locations are 
required. Port must Output the additional 
lines. 

Port 1 can be placed in the high-impedance 
state along with Port 0, AS, DS and R/W, 



allowing the Z8 to share common resources in 
multiprocessor and DMA applications. Data 
transfers can be controlled by assigning P33 as a 
Bus Acknowledge input and P34 as a Bus 
Request output. 



^■- 



Z8 
MCU 



V HANDSHAKE CONTROLS 
} DAVi AND RDYi 
' (P33 AND P34) 



Figure 9a. Port 1 



Port can be programmed as a nibble I/O 
port, or as an address port for interfacing 
external memory. When used as an I/O port, 
Port may be placed under handshake con- 
trol. In this configuration. Port 3 lines P32 an d 
P35 are used as the handshake controls DAVq 
and RDYq. Handshake signal assignment is 
dictated by the I/O direction of the upper nibble 
PO4-PO7. 

For external memory references. Port can 
provide address bits As-An (lower nibble) or 
As-Ais (lower and upper* nibble) depending on 
the required address space. If the address range 
requires 12 bits or less, the upper nibble of Port 
can be programmed independently as I/O while 



the lower nibble is used for addressing. When 
Port nibbles are defined as address bits, they 
can be set to the highimpedance state along with 
Port 1 and the control signals AS, DS and R/W. 



Ni 



A k [ (I/O OR A8-A,5) 



MCU yi-y 



V HANDSHAKE CONTROLS 
> OAVo AND RDYo 
' (P32 AND PSs) 



Figure 9b. Port 



Port 2 bits can be programmed independently 
as input or output. The port is always available 
for I/O operations. In addition. Port 2 can be 
configured to provide open-drain outputs. 

Like Ports and 1 , Port 2 may also be 
placed under handshake control. In this con- 
figuration. Port 3 hnes P3i a nd P3 6 are used as 
the handshake controls lines DAV2 and RDY2. 
The handshake signal assignment for Port 3 lines 
P3i and P36 is. dictated by the direction (input or 
output) assigned to bit 7 of Port 2. 



Z8 
MCU 



^ HAND SHAKE CONTROLS 

[DAVaANDRDYj 

I (P3i AND P3e) 



Figure 9c. Port 2 



Port 3 lines can be configured as I/O or 
control lines. In either case,, the direction of the 
eight lines is fixed as four input (P3o-P33) and 
four output (P34-P37). For serial I/O, lines P3o 
and P37 are programmed as serial in and serial 
out respectively. 

Port 3 can also provide the following con- 
t rol fu nctions: handshake for Ports 0, 1 and 2 
(DAVand RDY); four external interrupt 
request signals (IRQ0-IRQ3); ti^er input and ' 
output signals ( Tj^ a nd Tqut) ^^d Data 
Memory Select (DM). 



Z8 
MCU 



Figure 9d. Port 3 
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Interrupts The Z8 allows six different interrupts from 

eight sources: the four Port 3 lines PSq-PSs, 
Serial In, Serial Out, and the two counter/timers. 
These interrupts are both maskable and 
prioritized. The Interrupt Mask register globally 
or individually enables or disables the six inter- 
rupt requests. When more than one interrupt is 
pending, priorities are resolved by a pro- 
grammable priority encoder that is controlled by 
■ the Interrupt Priority register. 

All Z8 interrupts are vectored.' When an inter- 
rupt request is granted, an interrupt machine 



cycle is entered. This disables all subsequent 
interrupts, saves the Program Counter and status 
flags, and branches to the program memory 
vector location reserved for that interrupt. This 
memory location and the next byte cbntain the 
16-bit address of the interrupt service routine for 
that particular interrupt request. 

Polled interrupt systems are also supported. To 
accommodate a polled structure, any or all of the 
interrupt inputs can be masked and the Interrupt 
Request register polled to determine which of the 
interrupt requests needs serviqe. 



Clock The on-chip oscillator has a high-gain, 

parallel-resonant amplifier for connection to a 
crystal or to any suitable external clock source 
(XTALI = Input, XTAL2 = Output). 

The crystal source is connected across XTALI 
and XTAL2, using the recommended capacitors 



(Ci < 15 pF) from each pin to ground. The 
specifications for the crystal are as follows: 

■ AT cut, parallel resonant 

■ Fundamental type, 12.5 MHz maximum 

■ Series resistance, Rg < 100 Q 
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Z8603/13 The Z8 Protopack is used for prototype 

Protopack development and preproduction of mask- 

Emulator programmed applications. The Protopack is a 

ROMless version of the standard Z8601 or Z8611 
housed in a pin-compatible 40-pin package 
(Figure 11). 

To provide pin compatibility and interchange- 
ability with the standard maskprogrammed 
device, the Protppack carries piggy-back a 24- 
pin socket for a direct interface to program 
memory (Figure 1). The Z8603 24-pin socket is 
equipped with 1 1 ROM address lines, 8 ROM 
data lines and necessary control lines for inter- 
, face to 2716 EPROM for the first 2K bytes of pro- 
gram memory. The Z8613 24-pin socket is 




Figure 11. The Z8 Microcomputer Protopack Emulator 



equippfed with 12 ROM address lines, 8 ROM 
data lines and necessary control lines for inter- 
face to 2732 EPROM for the first 4K bytes of - 
program memory. 

Pin compatibility allows the user to design the 
pc board for a final 40-pin maskprogrammed 
Z8, and, at the same time, allows the use of the 
Protopack to build the prototype and pilot 
production units. When the final program is 
established, the user can then switch over to the 
40-pin mask-programmed Z6 for large volume 
production. The Protopack is also useful in 
small volume applica tions where masked ROM 
setup time, mask charges, etc., are prohibitive 
and program flexibility is desired. 

Compared to the conventional EPROM 
versions of the single-chip microcomputers, the 
Protopack approach offers two main 
advantages: 

■ Ease of developing various programs during 
the prototyping stage. For instance, in appli- 
cations where the same hardware configura- 
tion is used with more than one program, the 
Protopack allows economical program 
storage in separate EPROMs (or PROMs), 
whereas the use of separate EPROM-based 
single- chip microcomputers is more costly. 

■ Elimination of long lead time in procuring 
EPROM-based microcomputers. 



Instruction Addressing Modes. The following notation is used 

Set to describe the addressing modes and instruction 

Notation operations as shown in the instruction summary. 



IRR Indirect register pair or indirect working-register 

pair address 

Irr Indirect working -register pair only 

X Indexed address 

DA Direct address 

RA Relative address 

IM Immediate 

R Register or working- register address 

r Working-register address only 

IR Indirect-register or indirect working- register 

address 

Ir Indirect working-register address only 

RR Register pair or working register pair "address 

Symbols. The following symbols are used in 

describing the instruction set. 

dst Destination location or contents 

src Source location or contents 

cc Condition code (see list) 

@ Indire.ct address prefix 

SP Stack pointer (control registers 254-255) 

PC Program counter 

FLAGS Flag register (control register 252) 

RP Register pointer (control register 253) 

IMR Interrupt mask register (control register 251) 



Assignment of a value is indicated by the symbol 
''*-". For example, 

dst *- dst + src 
indicates that the source data is added to the 
destination data and the result is stored in the 
destination location. The notation "addr(n)" is used 
to refer to bit ' n" of a given location. For example, 

dst (7) 
refers to bjt 7 of the destination operand. 

Flags. Control Register R252 contains the following 
"six flags: 

C Carry flag 

Z Zero flag 

S Sign flag 

V Overflow flag 

D Decimal-adjust flag 

' H Half-carry flag 

Affected flags are indicated by: 

Cleared to zero 

1 Set to one ; 

* Set or cleared according to operation 

— Unaffected 

X Undefined ' 
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Condition 


Value 


Mnemonic 


Meaning 




Flags Set 


Codes 


1000 




Always true 








0111 


C 


Carry 




C = 1 




nil 


NC 


No carry 




C = 




Olio 


Z 


Zero 




Z = 1 




1110 


NZ 


Not zero 




Z = 




1101 


PL 


Plus 




S = 




0101 


MI 


Minus 




S = 1 




0100 


OV 


Overflow 




V = 1 




1100 


NOV 


No overflow 




V = 




Olio 


EQ 


Equal 




Z = 1 




1110 


NE 


Not equal 




Z = 




1001 


GE 


Greater than or equal 




(S XOR V) = 




, 0001 


LT ' 


Less than 




(S XOR V) = 1 




1010 


GT 


Greater than 




[Z OR (S XOR V)] = 




0010 


LE 


Less than or equal 




(Z OR (S XOR V)] = 1 




nil 


UGE 


Unsigned greater than 


or equal 


C = 




0111 


ULT 


Unsigned less than 




C = 1 




1011 


UGT 


Unsigned greater than 




(C - AND Z = 0) = 1 




0011 


ULE 


Unsigned less than or equal 


(C OR Z) = 1 




0000 




Never true 






Instruction 












Formats 






OPC 1 


CCF, Dl, El, IRET, NOP, 










INCr 






dst 1 OPC 1 





One-Byte Instructions 



OPC I MODE 



CLR, CPL, DA, DEC, 



OR ll 1 1 oldst/src I ''ECW, INC. INCW, POP, 
OR |1 1 1 0|dsl/src I p g _ - 



OR |l 1 1 61 dst I 



OPC 


MODE 


dst 


src 



MODE 


OPC 


dst/src 


src/dst 



I OPC 



dst/CC I OPC 



JP, CALL (Indirect) 



ADC, ADD, AND, 
CP, OR, SBC, SUB, 
TCM, TM, XOR 



dst/sfc I 0PC~ 

sr c/dst I OR |1 1 1 0| src | 



OPC 1 MODE 








src 


OR 
OR 


1110 


src ' 


dst 


1110 


dst 








OPC 1 MODE 


OR 


dst 


1 1 1 o| dst 1 


VALUE 








MODE 1 OPC 






src 


OR 
OR 


1110 


src 


dst 


1110 


dst 










OPC 




dst/src 


X 




ADDRESS 








cc 1 OPC 




DAu 




DAl 








OPC 




DAu 




DAl 





ADC, ADO, AND. CP, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 



ADC, ADD, AND, CP, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 



Two-Byte Instructions 



Three-Byte Instructions 



Figure 12. Instruction Formats 
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Instruction 
Summary 



Instruction Addr Mode Opcode Flags Affected 

and Operation j . "Y*® 

P^ " ° dst src (Hex) C 2 S V D H 



ADC dst,src 
dst *- dst + src + 


(Note 1) 
C 


ID 


* * * * * 


ADD dst, src 
dst *- dst + src 


(Note 1) 


on 


* * * * * 


AND dst, src (Note 1) 
dst - dst AND src 


sn 


_ * * - - 


CALL dst 

SP- SP-2 
@SP - PC; PC - 


DA 
IRR 
•dst 


D6 
D4 




CCF 

C - NOT C 




EF 


* 


CLR dst 

dst-0 


R 

IR 


BO ' 
Bl 




COM dst 

dst - NOT dst 


R 

IR 


60 
61 


_ * * - - 


CP dst,src 
dst - src 


(Note 1) 


AD 


****__ 


DA dst 

dst - DA dst 


R 
IR 


40 
41 


* * * X - - 


DEC dst 

dst - dst - 1 


R 

IR 


00 
01 


— *. * * 


DECW dst 

dst *- dst - 1 


RR 
IR 


80 
81 


_ * * * 


DI 

IMR (7) - 




8F 





DJNZ r,dst 
r- r- 1 
if r gfc 

PC *- PC + dst 
Range: +127, -128 



RA 



rA 
= 0-F 



EI 

IMR (7) «- 1 




9F - 


INC dst 

dst - dst + 1 


r 

R 
IR 


rE -***-- 
r = 0-F 
20 
21 


INCW dst 

dst - dst + 1 


RR 
IR 


AO _***-- 
Al 


IRET 

FLAGS -@SP; SP - SP + 1 
PC-@SP; SP^SP + 2; IMR (7) 


BF ****** 
- 1 


JP ccdst 
if cc is true 
PC - dst 


DA 
IRR 


cD 

c = 0-F 

30 


JR ccdst 
if cc is true, 

PC *- PC + dst 
Range: + 127, -128 


RA 


cB 

c = 0-F 



LD dst, src 
dst — src 



Ir 
R 
R 
R 
IR 
IR 



Im 
R 



R 
IR 
Im 
Im 
R 



rC 
r8 
r9 
r = 0-F 
C7 
D7 
E3 
F3 
E4 
E5 
E6 
E7 
F5 



LDC;dst,src 
dst — src 



Irr 



Irr 



C2 
D2 



LDCI dst,src Ir Irr C3 

dst — src Irr Ir D3 

r — r+l;rr — rr+1 



Instruction Addr Mode 
and Operation ^^^ ^^ 



Opcode Flags Affected 

Byte 

(Hex) CZSVDH 



LDE dst, src r 
dst -*- src Irr 


Irr 
r 


82 
92 


- 


- 





LDEI dst, src Ir 
dst — src Irr 
r-^r+ 1; rr*-rr+ 1 


Irr 
Ir 


83 
93 


- 


- 





NOP 




FF 


- 


- 




OR dst.src (Note 1) 
dst -dst OR src 


4D 


- 


* 


* - - 


POP dst R 

d8t-@SP IR 
SP - SP + 1 




50 
51 


- 


- 





PUSH stc 

SP-SP-1; @SP-src 


R 
IR 


70 
71 


- 


- 





RCF 

C-0 




CF 





- 





RET 

PC-@SP; SP-SP'+2 




AF 


- 


- 









90 
91 


, * 


* 




RLdst ^3i,^--3jR 








10 
11 


* 


* 




RLCdst^^^^^^_^R 








EO 
El 


* 


* 




RHdst L0Le=:^R 








CO 
CI 


* 


* 




RRCdstL^^^^^_^R 




SBC dst, src (Note 
dst -dst- src -C 


'D 


3D 


* 


* 


* * 1 * 


SCF 

C- 1 




DF 


1 














DO 
Dl 


* 


* 




SHA dst Lm .^n-nJ R 


* - - 


SRP src 

RP - src 


Im 


31 


-' 


- 





SUB dst, src (Note 
dst — dst - src 


1) 


2D 


* 


* 


* * 1 * 


SWAP dst 1 t 1 R 

' 1 ' ^ ' IR 




FO 
Fl 


X 


* 


* X - - 


TCM dst, src (Note 1) 
(NOT dst) AND src 


6a 


- 


* 


* - - 


TM dst, src (Note 1) 
dst AND src 


7D , 


- 


* 


* - - 


XOR dst,src (Note 
dst- dst XOR src 


1) 


BD 


- 


* 


* - - 



Notel 

These instructions have an identical set of addressing 
modes, which are encoded for brevity. The first opcode 
nibble is found in the instruction set table above. The 
second nibble is expressed symbolically by a D in this 
table, and its value is found in the following table to the 
right of the applicable addressing mode pair. 

For example, to determine the opcode of a ADC 
instruction use the addressing modes r (destination) and 
Ir (source). The result is 13. 



Addr Mode 



dst 


src 


r 


r 


r 


Ir 


R 


R 


R 


IR 


R 


IM 


IR 


IM 



Lower 
Opcode Nibble 



m 
a 

[E 
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Registers 



R240 SIO 
Serial I/O Register 

(FOh; Read/Write) 



R244 TO 
Counter/Timer Register 

(F4h; Read/Write) 



|D,|D6|D5|D4|D3|Da|D, |Do"i 



- SERIAL DATA (Dq = LSB) 



ID7ID6ID5ID4ID3ID2ID1ID0I 



To INITIAL VALUE (WHEN WRITTEN) 

-(RANGE: 1-256 DECIMAL 01-00 HEX) 

To CURRENT VALUE (WHEN READ) 



R241 TMR 
Timer Mode Register 

(FIh; Read/Write) 



R245 PREO 
Prescaler Register 

(F5h; Write Only) 



Tout MODES 

NOT USED = 00 

To OUT » 01 - 

Ti OUT = 10 

INTERNAL CLOCK OUT = 11 

Tin MODES 
EXTERNAL CLOCK INPUT = 00 
QATE INPUT = 01 
TRIQQER INPUT = 10 - 
(NONRETRIGGERABLE) 

TRIQQER INPUT = 11 
(RETRIQGERABLE) 



D4 I Da I D2 I 



3 

Lo = ^ 



H= 



°i|p.|Pi|p, Kl 



L 



COUNT MODE 

= To SINGLE-PASS 

1 = To MODULO-N 



PRESCALER MODULO 
-(RANGE: 1-64 DECIMAL 
01-00 HEX) 



R242 Tl 
Counter Timer 1 Register 

(F2h; Read/Write) 



R246 P2M 
Port 2 Mode Register 

(F6h; Write Only) 



}D7|D6|D5|D4|D3|D2|Di|D( 



|D,|D,|D5|D4|D3|Da|D,|Do| 



T, CURRENT VALUE (WHEN READ) 



P2o-P27 I/O DEFINITION 
- DEFINES BIT AS OUTPUT 
1 DEFINES BIT AS INPUT 



R243 PREl 
Prescoler 1 Register 

(F3h; Write Only) 



R247 P3M 
Port 3 Mode Register 

(F7h; Write Only) 



3;£7Id 



COUNT MODE 
- - T, SINGLE-PASS 
1 - T^ MODULO-N 

CLOCK SOURCE 
„ 1 = Ti INTERNAL 

= t, external timing input 
(t,n) mode 



Lo 



P33 
1 1 
-10)P33 
11 P33 



INPUT P34 

INPUT P34 : 

OffTl/RDVI P34 -. 



OUTPUT 

m 

RDY1/DAV1 



Figure 13. Control Registers 
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Registers 

(Continued) 



R248 POIM 
Port and 1 Mode Reglttw 

(F8h; Write Only) 



R252 FLAGS 
Flag Register 

(FCh; Read/Write) 



PO4.PO7 MODE 

OUTPUT = 00 

INPUT = 01 

Ai2-A,5 = IX 

EXTERNAL MEMORY TIMING 

NORMAL = 

EXTENDED = 1 



iDrlDfilDslo* 


D3ID2ID1ID0I 


-J 









PO0-PO3 MODE 

00 = OUTPUT 

01 « INPUT 
IX = Ag-Ai, 

STACK SELECTION 

■ EXTERNAL 

1 - INTERNAL 

P1«-P17 MODE 

00 = BYTE OUTPUT 

01 = BYTE INPUT 

10 = AD0-AD7 

11 B HLGHMMPEOANCE AD0-AD7, 

AS, DS, R/W, A8-A11, A12-A15 
IF SELECTED 



|d7|.D6|d5|d4|d3|d2|di|do| 



^: 



USER FLAG F1 

USER FLAG F2 
-HALF CARRY FLAG" 
-DECIMAL ADJUST FLAG 
-OVERFLOW, FLAG 
-SIGN FLAG 



-CARRY FLAG 



R249IPR 
Interrupt Priority Register 

(F9h; Write Only) 



R253 RP 
Register Pointer 

(FDh; Read/Write) 



D7 [ Ds I D5 I D4 I D3 I D2 I Di foTI 



IRQ3, IRQ5 PRIORITY (GROUP A) 

= IRQ5 > IRQ3 - 

1 = IRQ3 > IRQS 

IRQO, IRQ2 PRIORITY (GROUP B) 

= IRQ2 > IRQO - 

1 = IRQO > IRQ2 



IRQ1, IRQ4 PRIORITY (GROUP C) 

= IRQ1 > IRQ4 - 

1 = IRQ4 > IRQ1 



INTERRUPT GROUP PRIORITY 


RESERVED = 


000 


C > A> B = 


001 


- A > B > C = 


010 


A > C > B = 


Oil 


B > C > A = 


100 


C > B > A = 


101 


B > A > C = 


110 


RESERVED = 


111 



B3 



i-n 



1333 



R250 IRQ 
Interrupt Request Register 

(FAh; Read/Write) 



R254 SPH 
Stack Pointer 

(FEh; Read/Write) 



|D7|D6|D5|D4|D3|D2|D, |Do| 



- IRQO = P32 INPUT (Do = IRQO) 
IRQ1 = P33 INPUT 
IRQ2 = P3i INPUT 
IRQS = P3o INPUT, SERIAL INPUT 
IRQ4 = To, SERIAL OUTPUT 
IRQS = Ti 



R251 IMR 
Interrupt Mask Register 

(FBh; Read/Write) 



R255 SPL 
Stack Pointer 

(FFh; Read/Write) 



I D7 I D, I D. I D4 I D3 I D2 I Di I Dp I 



|D7[D,|D5|D4JD3|D2|D, |Do| 



- 1 ENABLES INTERRUPTS 



Figure 13. Control Registers (Continued) 
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2037-014 



Opcode 
Map 


1 


Lower Nibble (Hex) 
23456789ABCDEF 





6.5 

DEC 

Ri 


6,5 
DEC 

IRi 


6,5 

ADD 

ri,r2 


6,5 

ADD 

ri,Ir2 


10,5 

ADD 

R2,Ri 


10,5 
ADD 

IR2,Ri 


10,5 
ADD 

Ri,IM 


10,5 
ADD 

IRi,IM 


6,5 
LD 

ri,R2 


6,5 
LD 

12, Ri 


12/10,5 
DJNZ 
ri,RA 


12/10,0 

IR 

cc,RA 


6,5 
LD 
ri,IM 


12/10,0 

IP 
cc,DA 


6,5 
INC 

ri 




1 


6,5 

RLC 

Ri 


6,5 

RLC 

IRi 


6,5 

ADC 

ri,r2 


6,5 

ADC 

ri,Ir2 


10,5 

ADC 

R2,Ri 


10,5 

ADC 

IR2,Ri 


10,5 

ADC 

Ri.IM 


10,5 

ADC 

IRi,IM 


1 


r' 


' 


' 


1 


f 


1 


r 


1 


r 


1 


f 


^ 


' 




2 


6,5 
INC 

Ri 


6,5 
INC 

IRi 


6,5 

SUB 

ri,r2 


6,5 

SUB 

ri,Ir2 


10,5 
SUB 

R2,Ri 


10,5 

SUB 

IR2,Ri 


10,5 

SUB 

Ri,IM 


10,5 

SUB 

IRi,IM 




3 


8,0 

IP 

IRRi 


6,1 
SRP 

IM 


6,5 

SBC 

ri,r2 


6,5 

SBC 

ri,Ir2 


10,5 
SBC 

R2,Ri 


10,5 
SBC 
IR2,Ri 


10,5 
SBC 

Ri,IM 


10,5 

SBC 

IRi,IM 




4 


8,5 
DA 
Ri 


8,5 
DA 
IRi 


6,5 
OR 

ri, 12 


6,5 

OR 

ri,Ir2 


10,5 
OR 
R2,Ri 


10,5 

OR 

IR2,Ri 


10,5 

OR 

Ri,IM 


10,5 
OR 

IRi,IM 




5 


10,5 
POP 
Ri 


10,5 
POP 

IRi 


6,5 
AND 

ri,r2 


6,5 
AND 

ri,Ir2 


10,5 
AND 
R2,Ri 


10,5 
AND 
IR2,Ri 


10,5 
AND 

Ri,IM 


10,5 
AND 

IRi,IM 




1 • 


6,5 

COM 

Ri 


6,5 
COM 

IRi 


6,5 
TCM 

ri,r2 


6,5 
TCM 

ri,Ir2 


10,5 
TCM 
R2,Ri 


10,5 
TCM 
IR2,Ri 


10,5 
TCM 

Ri,IM 


10,5 
TCM 
IRi,IM 




1 • 


10/12, 1 
PUSH 

R2 


12/14, 1 

PUSH 

IR2 


6,5 
TM 

ri,r2 


6,5 
TM 

ri,Ir2 


10,5 
TM 
R2,Ri 


10,5 

TM 

IR2,Ri 


10,5 

TM 

Ri,IM 


10,5 

TM 

IRi,IM 




10,5 

DECW 

RRi 


10,5 

DECW 

IRi 


12,0 
LDE 

ri,Irr2 


18,0 
LDEI 

Iri,Irr2 










6,1 
DI 


9 


6,5 
RL 
Ri 


6,5 
RL 

IRi 


12,0 
LDE 

Irri 


18,0 
LDEI 

Ir2,Irri 










6,1 
EI 


A 


10,5 

INCW 

RRi 


10,5 

INCW 

IRi 


6,5 
CP 

ri,r2 


6,5 

CP 

ri,Ir2 


10,5 

CP 

R2,Ri 


10,5 

CP 

IR2,Ri 


10,5 

CP 

Ri,IM 


10,5 

CP 

IRl,IM 


14,0 
RET 


B 


6,5 
CLR 
Ri 


6,5 
CLR 

IRi 


6,5 
XOR 

ri,r2 


6,5 
XOR 

ri,Ir2 


10,5 
XOR 

R2,Ri 


10,5 
XOR 

IR2,Ri 


10,5 
XOR 

Ri,IM 


10,5 
XOR 

IRi,IM 


16,0 
IRET 


C 


6,5 
RRC 

Ri 


6,5 
RRC 
IRi 


12,0 

LDC 

n, Irr2 


18,0 

LDCI 

Iri,Irr2 








10,5 

LD 

ri, X, R2 


6,5 
RCF 


D 


6,5 
SRA 
Ri 


6,5 
SRA 

IRi 


12,0 

LDC 

r2,Irri 


18,0 
LDCI 

Ir2,Irri 


20,0 

CALL* 

IRRi 




20,0 

CALL 

DA 


10,5 
LD 

12, X, Rl 


6,5 
SCF 


E 


6,5 
RR 
Ri 


6,5 
RR 
IRi 




6,5 

LD 

ri, Ir2 


10,5 

LD 

R2,Ri 


10,5 

LD 

IR2,Ri 


10,5 

LD 

Ri,IM 


10,5 

LD 

IRi,IM 


6,5 
CCF 


F 


8,5 
SWAP 

Ri 


8,5 
SWAP 

IRi 




6,5 
LD 

Iri,r2 




10,5 

LD 

R2,IRi 






6,0 
NOP 




V._. 


^ S^ v* V ^ . ^ 






Bytes per 
Instruction 




2 








3 
















I 












3 


1 





Lower 
Opcode 
Nibble 

Execution f Pipeline 

Cycles < 4 > Cycles 



Upper 

Opcode - 

Nibble 



w 



10,5 

CP 

R2,Ri 



- Mnemonic 



First ' 
Operand 



^ Second 
Operand 



Legend: 

R = 8-Bit Address 
r = 4-Bit Address 
Ri or n 5= Dst Address 
R2 or r2 = Src Address 

Sequence: 

Opcode, First Operand, Second Operand 

Note: The blank areas are not defined. 



*2-byte instruction; fetch cycle appears as a 3-byte instruction 
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Absolute 

Maximum 

Ratings 



Voltages on all pins 

with respect to GND . . -0.3 V to 4-7.0 V 

Operating Ambient 

Temperature See Ordering Information 

Storage Temperature . ... -65°Cto +150°C 

The DC characteristics listed below apply for 
the following standard test conditions, unless 
otherwise noted. All voltages are referenced to 
GND. Positive current flows into the reference 
pin. 

Standard conditions are: 

D +4.75 V < Vcc :^ +5.25 V 

n GND = V 

D 0°C < T;^ < +70°C 



Stresses greater than those listed under Absolute Maxi- 
mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliabiUty. 



FROM OUTPUT . 



isopFri:: 




Figure 14. Test Load 1 



DC 

Character- 
istics 



Symbol Parameter 


Min 


Max 


Unit 


Condition 


VCH 


Clock Input High Voltage 


3.8 


Vcc 


, V 


Driven by External Clock Generator 


VCL 


Clock Input Low Voltage 


-0.3 


0.8 


V 


Driven by External Clock Generator 


VlH 


Input High Voltage 


2.0 


Vcc 


V 




ViL 


Input Low Voltage* 


-0.3 


0.8 


V 




Vrh 


Reset Input High Voltage 


3.8 


Vcc 


V 




Vrl 


Reset Input Low Voltage 


-0.3 


0.8 


V 




VOH 


Output High Voltage 


2.4 




V 


Ioh = -250mA 


VOT. 


Output Low Voltage 




0.4 


V 


Iql = +2.0 mA 


IlL 


Input Leakage 


-10 


10 


mA 


0V< ViN < +5.25 V 


lOL 


Output Leakage 


-10 


10 


ItA 


V< ViN < +5.25 V 


IlR 


Reset Input Current 




-50 


liA 


Vcc = +5.25 V, Vrl = OV 


Ice 


Vcc Supply Current 




150 


mA 
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AC Characteristics 



External I/O 
or Memory 
Read and 
Write Timing 



3C 



♦<12>^ 



PORT 0, 
DM 



X 



y: 



K 



♦(i>- 



~)=^' 



DS 

(READ) 



DS 

(WRITE) 



X 



-•-<J3>^ 



a-A7 ^ \ 



^ 



-® — ^ 



-dh 



^ D0-D7 \t 



-<!>- 



:x 



X 



-0- 



—01^ 



/ 



:ci 



) <: 



'*<^ 



\ 



•*^^ 



K 



y 



Figure 15. External I/O or Memory Read/Write 



No. 


Symbol 


1 


TdA(AS) 


2 


TdAS(A) 


3 


TdAS(DR) 


4 


TwAS 


5 
6- 


TdAz(DS) 


iwUolt 


7 


TwDSW 


8 


TdDSR(DR) 


9 


ThDR(DS) 


10 


TdDS(A) 


11 
12- 


TdDS(AS) 


■ lull/W(AiJj 


13 


TdDS(R/W) 


14 


TdDW(DSW) 


15 


TdDS(DW) 


16 


TdA(DR) 


17 


TdAS(DSy 



Parameter 



8 MHz 
Min Max 



12.5 MHz 
Min Max 



Notes*t*' 



Address Valid to AS t Delay 50 35 

AST to Address Float Delay 60 45 

AS t to Read Data Required Valid 320 220 

AS Low Width 80 55 

Address Float to DS i Q 

DS (Read) Low Width 250 185 

DS (Write) Low Width 160 110 

DS i to Read Data Required Valid 200 1 30 

Read Data to DS t Hold Time 

DS t to Address Active Delay 80 45 

DSTtoASiDelay 70 55 

R/W Valid to AS t Delay 50 30 

DSt to R/W Not Valid 60 35 

Write Data Valid to DS (Write) i Delay 50 35 

DS t to Write Data Not Valid Delay 80 45 

Address Valid to Read Data Required Valid 410 255 

ASttoDSiDelay 80 55 



2,3 
2,3 
1,2,3 
1,2,3 

-1,2,3 
1,2,3 
1,2,3 

2,3 
2.3 
-2,3 
2,3 
2,3 
2,3 
1,2,3 
2,3 



NOTES: 

1 . When using extended memory timing add 2 TpC. 

2. Timing numbers given are for minimum TpC. 

^. See clock cycle time dependent characteristics table. 



t Test Load 1 . 

° All timing references use 2.0 V for a logic "1 " and 0.8 V for a logic "0". 

* All units in nanoseconds (ns) . 
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AC Characteristics 



Additional 

Timing 

Table 



-dh 



^:^^~]W4 





\^4~: 



Figure 16. Additional Timing 



No. Symbol 



Parameter 



8 MHz 
Min Max 



12.5 MHz 
Min Max 



Notes* 



1 TpC 

2 TrCJfC 

3 TwC 

4 TwTinL 

5 — TwTinH 

6 TpTin 

7 TrTin,TfTin 
8a TwIL 

8b TwIL 

9 TwIH 

_s 



Input Clock Period 

Clock Input Rise And Fall Times 

Input Clock Width 

Time Input Low Width 

- Timer Input High Width 

Timer Input Period 
Timer Input Rise And Fall Times 
Interrupt Request Input Low Time 
Interrupt Request Input Low Time 
Interrupt Request Input High Time 



125 


1000 


80 


1000 


1 




25 




15 


1 


37 
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I 


100 




70 




2 












BTpC 




8TpC 




2 




100 




100 


2 


100 




70 




2,3 




3TpC 


3TpC 




2,4 




3TpC 


3TpC 




2,3 



NOTES: 

1 . Clock timing references uses 3.8 V for a logic "1" and 0.8 V for 
a logic "0". 

2. Timing reference uses 2.0 V for a logic "1 " and 0.8 V for 
a logic "0". 



3. Interrupt request via Port 3 (P3i-P33). 

4. Interrupt request via Port 3 (P3o)- 
* Units in nanoseconds (ns). 



Memory Port 
Timing 



X 



-<j>- 



ADDRESS VALID 



DATA IN VALID 



X 



:c 







Figure 17. Memory Port Timing 








No. 


Symbol 


Parameter 


Min 


Max 


Notes* 


1 

2 


TdA(DI) 
ThDI(A) 


Address Valid to Data Input Delay 
Data In Hold time 





320 


1,2 

1 



NOTES: 

1. Test Load 2. 

2. This is a Clock-Cycle- Dependent parameter. For clock frequencies 
other than the maximum, use the following formula: 5 TpC - 95 



* Units are nanoseconds unless otherwise specified. 
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2194-012 2037-019 



Handshake 
Timing 



?£ 



DATA IN VALID 



\ 



-0- 



0-1 



d/r 



\ 



-CD- 



Jr 



Figure 18a. Input Handshoke 



i: 



DATA OUT VALID 



daV 

(OUTPUT) 



V 



-ay 



\ 



<!) 



-CD- 



r 



Figure 18b. Output Handshcdce 



No. Symbol 



Param*t*r 



Min 



Max 



Notes* 



TsDI(DAV) 
ThDI(DAV) 
TwDAV 
rdDAVIf(RDY) 
-TdDAVOf(RDY)- 
TdDAVIKRDY) 
TdDAVOr(RDY) 
TdDO(DAV) 
TdRDY(DAV) 



Data In Setup Time 
Data In Hold time 
Data Available Width 
D:^ i Input to RDY i Delay 
- DAV i Output to RDY i Delay - 
DAATT Input to RDY t Delay 
DAV r Output to RDY t Delay 
Data Out to D^i Delay 
Rdy I Input to DM t Delay 




160 
120 





30 




120 



120 



140 



1,2 

"1,3 

1,2 

1,3 

1 

1 



NOTES: 

1. Test load 1 

2. Input handshake 

3. Output handahakw 

t All timing referenoe* use 2.0 V for a logic " I " and 0.8 V for 
a logic '^C. 



* Units in nanoseconds (ns). 



Clock- 

Cycle-Tim*- Number Symbol 

Dependent 

Charact«riiiict 



Equation 



1 TdA(AS) 

2 TdAS(A) 

3 TdAS(DR) 

4 TwAS 

5- TwDSR 



7 

8 
10 
11 
12- 
13 
14 
15 
16 
17 



TwDSW 
TdDSR(DR) 
Td(DS)A 
TdDS(AS) 
-TdR/W(AS)- 
TdDS(R/W) 
TdDW(DSW) 
TdDS(DW) 
TdA(DR) 
TdAS(DS) 



TpC-50 

TpC-40 

4TpC-110* 

TpC-30 

- 3TpC-65* - 
2TpC-55* 
3TpC-120* 

TpC-40 
TpC-30 

— TpG-55 — 
TpC-50 
TpC-50 
TpC-40 

5TpC-160* 
TpC-30 



*Add 2TpC when u»lng extended memory timing. 
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Product Specification 



Z8671 Z8® MCU 
with BASIC/Debug 
Interpreter 



June 1987 



FEATURES 

■ The Z8671 MCU is a complete microcomputer 
preprogrammed with a BASIC/Debug interpreter 
Interaction between the interpreter and its user is 
provided through an on-board UART. 

■ BASIC/Debug can directly address the Z8671's internal 
registers and all external memory. It provides quick 
examination and modification of any external memory 
location or I/O port. 



The BASIC/Debug interpreter can call machine 
language subroutines to increase execution speed. 

The Z8671's auto start-up capability allows a program to 
be executed on power-up or Reset without operator 
intervention. 

Single -i-5V power supply— all I/O pinsTTL-compatible. 

8 MHz 



M 

00 



GENERAL DESCRIPTION 



The Z8671 Single-Chip Microcomputer (MCU) is one of a 
line of preprogrammed chips— in this case with a 
BASIC/Debug interpreter in ROM— offered by Zilog. As a 
member of the Z8 Family of microcomputers, it offers the 
same abundance of resources as the other Z8 
microcomputers. 



Because the BASIC/Debug interpreter is already part of the 
chip circuit, programming is made much easier The Z8671 
MCU thus offers a combination of software and hardware 
that is ideal for many industrial control applications. The 
Z8671 MCU allows fast hardware tests and bit-by-bit 
examination and modification of mennory location, I/O ports. 



TIMING 
AND{ 
CONTROL 



PORTO 

(NIBBLE 
PROGRAMMABLE) 

I/O or Ab Ai5 



-* — ^ 

-• — * 



PORT 1 

I/O OR ADo-Al),' 



RESET 

R/W 

DS 

AS 

POo 

POi 

PO2 

PO3 

PO4 



Z8671 
MCU 



+ 5V 

GND 

XTAL1 

XTAL2 

P2o 

P2i 

P22 
P23 
P24 
P25 
P26 

P27 
P3o. 
P3i 

P32 
P33 
P34 
P35 
P36 
P37 



< — »■ 

4 » 

4 — » 
*— • 

♦— 

»■ ' - 
*— 
♦— — 

» 

— »- 



PORT 2 

(BIT PRO- 
GRAMMABLE) 

I/O 



PORTS 

SERIAL AND 
PARALLEL I/O 
AND CONTROL 







. ^ 






+ 5V 


L 


40 


JP3. 


XTAL2 


c 


2 


39 


3p3, 


XTAL1 


c 


3 


38 


JP2, 


P37 


c: 


4 


37 


DP2a 


P3o 


c: 


5 


36 


3 pa, 


RESET 


c 


6 


35 


Dp2. 


R/W 


L 


7 


34 


Dp23 


DS 


L 


8 


33 


J P22 


AS 


E 


9 


32 


3 P2i 


P35 


L 


10 Z8671 


31 


]P2o 


GND 


L 


11 •*«" 


30 


JPh 


P32 


C 


12 


29 


3P3. 


POo 


L 


13 


28 


3 AD7 


PO1 


L 


14 


27 


Dads 


PO2 


C 


15 


26 


]|ad5 


PO3 


L 


16 


25 


D AD4 


PO4 


L 


17 


24 


I]aD3 


PO5 


C 


18 


23 


3 AD2 


POe 


L 


19 


22 


JaDi 


PO7 


L 


20 


21 


3 ADo 



Figure 1 . Pin Functions 



Figure 2a. 40-pin Dual-ln-Llne Package (DIP), 
Pin Assignments 
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or registers, it also allows bit manipulation and logical 
operations. A self-contained line editor supports interactive 
debugginp'^urther speeding up program development. 

The BA3|(^|)ebug interpreter, a subset of Dartmouth 
BASIC, operates with three kinds of memory: on-chip 
registers and external ROM or RAM. The BASIC/Debug 
interpreter is located in the 2K bytes of on-chip ROM. 

Additional features of the Z8671 MCU include the ability to 
call machine language subroutines to increase execution 
speed and the ability to have a program execute on 
power-up or Reset, without operator intervention. 

Maximum memory addressing capabilities include 62K 
bytes of external program memory and 62K bytes of data 
memory with program storage beginning at location SOOh- 
This provides up to 124K bytes of useable memory space. 
Very few 8-bit microcomputers can directly access this 
amount of memory 

Each Z8671 Microcomputer has 32 I/O lines, a 144-byte 
register file, an on-board DART and two counter/timers. 





,, ^0 ^<,.^«,A ^^^\^^/ <f>\%<P^\^'' 


<?'^ 






/ 6 


5 4 3 2 1 44 4f^'42 41*^^40 X 




RESET 


: 


■ ^ i^ 'A 


^^f39 


NC 


R/W 




38 


P24 


DS 


9 




37 


P23 


AS 


10 




36 


P22 


P35 
GND 


11 
12 


Z8671 
MCU 


35 
34 


P2i 
P2o 


P32 


13 




33 


P33 


POo 


14 




32 


P34 


POi 


15 




31 


PI 7 


PO2 


16 
17 




3d 


P16 


NC 




29 


P15 




k^ 


19 20 21 22 23 24 25 26 27 28 X 





<f^'^<f>\^*' <f!f^<i>'^ <i'^'^ ^^^^^V^^*^^ '^^ 



Figure 2b. 44-pin Chip Carrier, 
Pin Assignments 



OUTPUT INPUT 



COUNTER/ 

TIMERS 

(2) 



INTERRUPT 
CONTROL 



R 



mm 



(BIT PROGRAMMABLE) 



Vcc GND 

I \ 



2£ 



REGISTER 
POINTER 



^ 



, XTAL AS DS R/W RESET 

ti t t t I 



REGISTER FILE 
124 X 8-BIT 



St. 



1 



MACHINE TIMING AND 
INSTRUCTION CONTROL 



:5T 



PROGRAM 

MEMORY 

2048 X 8BIT 



21. 



PROGRAM 
COUNTER 



3T 



U- 






ADDRESS OR I/O 
(NIBBLE PROGRAMMABLE) 



ADDRESS/DATA OR I/O 
(BYTE PROGRAMMABLE) 



Figure 3. Functional Bloclc Diagram 
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ARCHITECTURE 



Z8671 architecture is characterized b/ a flexible I/O 
scheme, an efficient register and address space structure, 
and a number of ancillary features that are helpful in many 
applications. 

Microcomputer applications demand powerful I/O 
capabilities. The Z8671 fulfills this with 32 pins dedicated to 
input and output; These lines are grouped into four ports of 
eight lines each and are configurable under software control 
to provide timing, status signals, serial or parallel I/O with or 
without handshake, and an address/data bus for interfacing 
external memory. - 

Because the multiplexed address/data bus is merged with 
the l/0-oriented ports, the Z8671 can assume many 
different memory and I/O configurations. These 
configurations range from a self-contained microcomputer 



to a microprocessor that can address 1 24K bytes of external 
memory. 

Three basic address spaces are available to support this 
wide range of configurations: program memory (internal 
and external), data memory (external) and the register file 
(internal). The 144-byte random-afecess register file is 
composed of 124 general-purpose registers, four I/O port 
registers, and 16 control and status registers.' 

To unburden the program from coping with real-time 
problems such as serial data communication and 
counting/timing, an asynchronous receiver/transmitter 
(DART) and two counter/timers with a large number of 
userselectable modes are offered on-chip. Hardware 
support for the DART is minimized because one of the 
on-chip timers supplies the bit rate. 



N 

i 



PIN DESCRIPTION 

AS. Address Strobe (output, active Low). Address Strobe is 
pulsed once at the beginning of each machine cycle. 
Addresses output via Port 1 for all external prograjin or data 
memory transfers are valid at the trailing edge of AS. Under 
program control, AS can be placed in the high-impedance 
state along with Ports and 1 , Data Strobe, and Read/Write. 

DS. Data Strobe (output, active Low). Data Strobe is 
activated once for each external memory transfer 

PO0-PO7, PI0-PI7, P2o-P27, P3o-P37. I/O Port Lines 
(input/outputs, TTL-compatible). These 32 lines are divided 
into four 8-bit I/O ports that can be configured under 



program control for I/O or external memory interface. 



RESET. Reset (input, active Low). RESET initializes the 
Z8671. When RESET is deactivated, program execution 
begins from internal program location OOOCh- 

R/W. Read/Write (output). R/W is Low when the Z8671 is 
writing to external program or data memory. 

XTAL1, XTAL2. Crystal 1, Crystal 2 (time-base input and 
output). These pins connect a parallel-resonant crystal (8 
MHz maximum) or an external single-phase clock (8 MHz 
maximum) to the on-chip clock oscillator and buffer 



ADDRESS SPACES 

Program Memory. The Z8671's 16-bit program counter 
can address 64K bytes of program memory space. 
Program memory consists of 2K bytes of internal ROM and 
up to 62K bytes of external ROM, EPROM, or RAM. The first 
12 bytes of program memory are reserved for interrupt 
vectors (Figure 4). These locations contain six 1 6-bit vectors 
that correspond to the six available interrupts. The 
BASIC/Debug interpreter is located in the 2K bytes of 
internal ROM. The interpreter begins at address 12 and 
extends to 2047. 



65 
2 


535 

048 
047 

12 
11 
10 
9 
8 
7 
v6 
5 
4 
-^ 
2 
1 



EXTERNAL 
ROM OR RAM 




2 

Location of 
first byte of 
instruction^ 


ON-CHIP 
ROM 


I BASIC/ 
/ DEBUG 


after reset 


5^ 






tRQ5 






IRQ5 






IRQ4 






IRQ4 




Interrupt 

Vector^ 

(Lower Byte) 


IRQ3 




IRQ3 




>^ 


IRQ2 






Tf 


IRQ2 




Vector' 


IRQ1 




(Upper Byte) 


IRQ1 






IRQO 






IRQO 





Figure 4. Program Memory Map 
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Data Memory. The Z8671 can address up to 62K bytes of 
external data nnemory beginning at location 2048 (Figure 5). 
External data memory may be included with, or separated 
from, the external program memory space. DM, an optional 
I/O function that can be programmed to appear on pin P34, 
is used to distinguish data and program memory space. 

Register File. The 144-byte register file may be accessed 
by BASIC programs as memory locations 0-127 and 
240-255. The register file includes four I/O port registers 
(R0-R3), 124 general-purpose registers (R4-R127), and 16 
control and status registers (Figure 6). 

The BASIC/Debug Interpreter uses many of the general- 
purpose registers as pointers, scratch workspace, and 
internal variables. Consequently, these registers cannot be 
used by a machine language subroutine or other user 
programs. On power-up/Reset, BASIC/Debug searches for 
external RAM memory and checks for an auto start-up 
program. In a non-destructive method, memory is tested at 
relative location xxFDh- When BASIC/Debug discovers 
RAM in the system, it initializes the pointer registers to mark 
the boundaries between areas of memory that are assigned 
specific uses. The top page of RAM is allocated for the line 
buffer, variable storage, and the GOSUB stack. Figure 7a 



illustrates the^ contents of the general-purpose registers in 
the Z8671 system with external RAM. When BASIC/Debug 
tests memory and finds no RAM, it uses an internal stack 
and shares register space with the input line buffer and 
variables. Figure 7b illustrates the contents of the 
general-purpose registers in the Z8671 system' without 
external RAM. 

Stacks. Either the internal register file or the external data 
memory can be used for the stack. A 16-bit Stack Pointer 
(R254 and R255) is used for the external stack, which can 
reside anywhere in data memory between location 2048 
and 65535. An 8-bit Stack Pointer (R255) is used for the 
internal stack that resides within the 124 general-purpose 
registers (R4-R1 27). 

Register Addressing. Z8671 instructions can directly or 
indirectly access registers with an 8-bit address field. The 
Z8671 also allows short 4-bit register addressing using the 
Register Pointer, which is one of the control registers. In the 
4-bit mode, the register file is divided into nine 
working-register groups, each group consisting of 16 
contiguous registers (Figure 8). The Register Pointer 
addresses the starting location of the active working-register 
group. 



2048 
2047 



EXTERNAL 

DATA 
MEMORY 



NOT ADDRESSABLE 



LOCATION 




IDENTIFIERS 


255 


STACK POINTER (BITS 7-0) 


SPL 


254 


STACK POINTER (BITS 15-8) 


SPH 


253 


REGISTER POINTER 


RP 


252 


PROGRAM CONTROL FLAGS 


FLAGS 


251 




IMR 


250 


INTERRUPT REQUEST REGISTER 


IRQ 


249 


INTERRUPT PRIORITY REGISTER 


IPR 


248 


PORTS 0-1 MODE 


P01M 


247 


PORT 3 MODE 


P3M 


246 


PORT 2 MODE 


P2M 


245 


TO PRESCALER 


PREO 


244 


TIMER/COUNTER 


TO 


243 


T1 PRESCALER 


PRE1 


242 


TIMER/COUNTER 1 


T1 


241 


TIMER MODE 


TMR 


240 


SERIAL I/O 


SIO 




NOT 
IMPLEMENTED 





Figure 5. Data Memory Map 



Figure 6. Control and Status Registers 
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12/ 
104 


SHARED BY EXPRESSION 
STACK AND LINE BUFFER 


103 
86 


GOSUB 
STACK 


85 
64 


SHARED BY GOSUB 
AND VARIABLES 


63 
34 


VARIABLES 


33 


FREE, AVAILABLE 
FOR USR ROUTINES 


32 


COUNTER 


31 


USED INTERNALLY 


30 


SCRATCH 


29 
28 


POINTER TO 
CONSTANT BLOCK 


27 
24 


USED INTERNALLY 


23 
22 


LINE NUMBER 


21 
20 


ARGUMENT FOR 
SUBROUTINE CALL 


19 
18 


ARGUMENT/RESULT FOR 
SUBROUTINE CALL 


17 
16 


SCRATXJH 


15 
14 


POINTER TO NEXT 
CHARACTER 


13 
12 


POINTER TO LINE 
BUFFER 


11 
10 


POINTER TO GOSUB 


9 
8 


POINTER TO BASIC 
PROGRAM 


7 
6 


POINTER TO GOSUB 


5 
4 


FREE 


3 



I/O PORTS 



127 


EXPRESSION 




EVALUATION 




STACK 


64 




63 






FREE 


34 




33 
32 


COUNTER 


31 


USED INTERNALLY 


30 


SCRATCH 


29 


POINTER TO 


28 


CONSTANT BLOCK 


27 
24 


USED INTERNALLY 


23 
22 


LINE NUMBER 


21 


ARGUMENT FOR 


20 


SUBROUTINE 


19 


ARGUMENT/ROUTINE FOR 


18 


SUBROUTINE CALL 


17 
16 


SCRATCH 


15 


POINTER TO INPUT 


14 


LINE BUFFER 


13 


POINTER TO END OF 


12 


LINE BUFFER 


11 


POINTER TO STACK 


10 


BOTTOM 


9 


ADDRESS OF USER 


8 


PROGRAM 


7 


POINTER TO GOSUB 


6 


, STACK 


5 


POINTER TO END 


4 


OF PROGRAM 


3 


I/O PORTS 








M 

00 

3 



Figure 7a. General-Purpose Registers with External RAM Figure 7b. General-Purpose Registers without External RAM 



te fs U 



255 
253 



THE UPPER NIBBLE OF THE REGISTER 
FILE ADDRESS PROVIDED BY THE 
REGISTER POINTER SPECIFIES THE 
ACTIVE WORKING-REGISTER GROUP. 



SPECIFIED WORKING- 
REGISTER GROUP 



THE LOWER 
NIBBLE OF 
THE REGISTER 
FILE ADDRESS 
■ PROVIDED BY 
THE INSTRUCTION 
POINTS TO THE 
SPECIFIED 
REGISTER. 



Figure 8. The Register Pointer 
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PROGRAM EXECUTION 



Automatic Start-up. The Z8671 has an automatic start-up 
capability which allows a program stored in ROM to be 
executed without operator intervention. Automatic 
execution occurs on power-on or Reset when the program is 
stored at address 1 020h. 

Execution Modes. The Z8671's BASIC/Debug Interpreter 
operates in two execution modes: Run and Immediate. 



Programs are edited and interactively debugged in the 
Immediate mode. Some BASIC/Debug commands are 
used almost exclusively in this mode. The Run mode is 
entered from the Immediate mode by entering the 
command RUN. If there is a program in RAM, it is executed. 
The system returns to the Immediate mode when program 
execution is complete or interrupted by an error. 



INTERACTIVE DEBUGGING 



Interactive debugging is accohiplished with the self- 
contained line 'editor which operates in the Immediate 
mode. In addition to changing program lines, the editor can 
correct an immediate command before it is executed. It also 
allows the correction of typing and other errors as a program 
is entered. 

BASIC/Debug allows interruptions and changes during a 



program run to correct errors and add new instructions 
without disturbing the sequential execution of the program. 
A program run is interrupted with the use of the escape key. 
The run is restarted with a GOTO command, followed by the 
appropriate line number, after the desired changes are 
entered. The same procedure is used to enter corrections 
after BASIC/Debug returns an error. 



COMMANDS 



BASIC/Debug recognizes 15 command keywords. For 
detailed instructions of command usage, refer to the 
BASIC/Debug Software Reference Manual (#03-31 49-02). 

FO The GO command unconditionally branches 

to a machine language subroutine. This 
statement is similar to the USR function 
except that no value is returned by the 
assembly language routine. 

GOSUB GOSUB unconditionally branches to a 
subroutine at a line number specified by the 
user 

GOTO GOTO unconditionally changes the se- 

quence of program execution (branches to a 
line number). 

IF/THEN This command is used for conditional 
operations and branches. 

INPUT/IN These commands request information from 
the user with the prompt "?", then read the 
input values (which must be s^arated by 
commas) from the keyboard, and store them 
in the indicated variables. INPUT discards 
any values remaining in the buffer from 
previous IN, INPUT or RUN statements, and 
requests new data from the operator IN uses 



any values left in the buffer first, then requests 
new data. 

LET LET assigns the value of an expression to a 

variable or memory location. 

LIST This command is used in the interactive mode 

to generate a listing of program lines stored in 
memory on the terminal device. 

NEW The NEW command resets pointer R1 0-1 1 to 

the beginning of user memory, thereby 
marking the space as empty and ready to 
store a new program. 

PRINT PRINT lists its arguments^, which may be text 

messages or numerical values, on the output 
terminal. 

REM This command is used to insert explanatory 

messages into the program. 

RETURN This command returns control to the line 
following a GOSUB statement. 

RUN RUN initiates sequential execution of all 

instructions in the current program. 

STOP STOP ends program execution and clears the 

GOSUB stack. 
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FUNCTIONS 



BASIC/Debug supports two fu notions: AND and USR . 

The AND funotlon performs a logical AND. It can be used to 
mask, turn off, or isolate bits. This function is used in the 
following format: 

AND (expression, expression) 

The two expressions are evaluated, and their bit patterns are 
ANDed together If only one value is included in the 
parentheses, it is ANDed with Itself. A logical OR can also be 
performed by complementing the AND function. This is 
accomplished by subtracting each expression from -1 . For 
example, the function below is equivalent to the OR of A 
and B. 

-1-AND(-1-A,-1-B) 



The USR function calls a machine language subroutine and 
returns a value. This is useful for applications in which a 
subroutine can be performed more quickly and efficiently in 
machine language than in BASIC/Debug. 

The address of the first instruction of the subroutine is the 
first argument of the USR function. The address can be 
followed by one or two values to be processed by the 
subroutine. In the following example, BASIC/Debug 
executes the subroutine located at address 2000 using 
values literal 256 and variable C. 

USR(%2000,256,C) 

The resulting value is stored in Registers 18-19. 



SERIAL INPUT/OUTPUT 

Port 3 lines P3o and PSy can be programmed as serial I/O 
lines for full-duplex serial asynchronous receiver/transmitter . 
operation. Th© bit rate is controlled by Counter/Timer 0, with 
a maximum rate of 62. 5K bftsj^saooncf. 

The Z8671 automatically adds a start bit and two stop bits to 
transmitted data (Figure 9). Odd parity is also available as an 
option. Eight data bits are always transmitted, regardless of 



parity selection. If parity is enabled, the eighth data bit is 
used as the odd parity bit. An interrupt request (IRQ4) is 
generated on all transmitted characters. 

Received data must have a start bit, eight data bits, and at 
least one stop bit. If parity is on, bit 7 of the received data is 
replaced by a parity error flag. Received characters 
generate the IRQ3 interrupt request. 



0) 

3 



F 


sp|d7|d6|d5|d4 


D3|d2|di|do|st| 












L 









TRANSMITTED DATA 
(No Parity) 



START BIT 
EIGHT DATA BITS 
TWO STOP BITS 



|sp|d7|d6|d5|d4 


D3|d2|di|do|st| 












L 









RECEIVED DATA 
(No Parity) 



START BIT 
EIGHT DATA BITS 
ONE STOP BIT 



EE 


sp| p|d6|d5|d4|d3|d2|di|do|st| 








L 















-START BIT 
-SEVEN DATA BITS 
-ODD PARITY 
-TWO STOP BITS 



SP I P I De I Ds I D4 I Da I D2 1 D, I Dp I ST I 



START BIT 
SEVEN DATA BITS 
PARITY ERROR FLAG 
ONE STOP BIT 



TRANSMITTED DATA 
(With Parity) 



RECEIVED DATA 
(WItli Parity) 



Figure 9. Serial Data Formats 
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I/O PORTS 



The Z8671 has 32 lines dedicated to input and output. 
These lines are grouped into four ports of eight lines each 
and are configurable as input, output or address/data. 
Under software control, the ports can be progrannmed to 
provide address outputs, timing, status signals, serial I/O, 
and parallel I/O with or without handshake. All ports have 
active pull-ups and pull-downs compatible with TTL loads. 

Port 1 can be programmed as a byte I/O port or as an 
address/data port for interfacing external memory. When 
used as an I/O port, Port 1 may be placed under handshake 
control. In this configuration, Port 3 lines P3 3 and P34 are 
used as the handshake controls RDY1 and DAV1 (Ready 
and Data Available). 

Memory locations greater than 2048 are referenced 
through Port 1 . To interface external memory. Port 1 must be 
programmed for the multiplexed Address/Data mode. If 
more than 256 external locations are required, Port must 
output the additional lines. 

Port 1 can be placed in the_high-impedance state along with 
Port 0, AS, DS and R/W, allowing the Z8671 to share 
common resources in multiprocessor and DMA 
applications. Data transfers can be controlled by assigning 
P33 as a Bus Acknowledge input ancrP34 as a Bus Request 
output. 

Port can be programmed as a nibble I/O port, or as an 
address port for interfacing external memory. When used as 
an I/O port. Port may be placed under handshake control. 
In this configuration. P ort 3 li nes P32 and P35 are used as 
the handshake controls DAVO and RDYO. Handshake signal 
assignment is dictated by the I/O direction of the upper 
nibble PO4-PO7. 



For external memory references, Port can provide address 
bits As-A-i 1 (lower nibble) or A8-A-15 (lower and upper nibble) 
depending on the required address space. If the address 
range requires 1 2 bits or less, the upper nibble of Port can 
be programmed independently as I/O while the lower nibble 
is used for addressing. When Port nibbles are defined as 
address bits, they can be set to the high-impedance state 
along with Port 1 and the control signals AS, DS and R/W. 

Port 2 bits can be programmed independently as input or 
output. The port is always available for I/O operations. In 
addition. Port 2 can be configured to provide open-drain 
outputs. 

Like Ports and 1, Port 2 may also be placed under 
handshake control. In this configuration. Port 3 lines P3i 
and P36 are used as the handshake controls lines DAV2 and 
RDY2. The handshake signal assignment for Port 3 lines 
P3i and P36 is dictated by the direction (input or output) 
assigned to bit 7 of Port 2. 

Port 3 lines can be configured as I/O or control lines. In 
either case, the direction of the eight lines is fixed as four 
input (P3o-P33) and four output (P34-P37). For serial I/O, 
lines P3o and P37 are programmed as serial in and serial out 
respectively. 

Port 3 can also provide the follow ing control functions: 
handshake for Ports 0, 1 and 2 (DAV and RDY); four external 
interrupt request signals (IRQ0-IRQ3); timer input and 
output signals (Tin and Tqut) and Data Memory Select 
(DM). 



Z8671 
MPU 



/ K PORT 1 

\ ^ / ("0 OR AD0-AD7) PI0-PI7 



, HAND SHAKE CONTROLS 
\ DAV1 AND RDY1 
' (P33ANDP34) 











Z8671 
MCU 


-^ 








^ 







, HANDSHAKE CONTROLS 

DAV2ANDRDY2 
' (P13ANDP36) 



Figure 10a. Port 1 



Figure 10c. Port 2 



Z8671 
MCU 






PO4-PO7 V PORT O 
PO0-PO3 f(l/OOR A8-Ai5> 



, HAND SHAKE CONTROLS 
DAVO AND RDYO 
(P32 AND P35) 













* 






Z8671 




MCU 













PORTS 

(I/O OR CONTROL) 



Figure 10b. Port 



Figure lOd. Ports 
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COUNTER/TIMERS 



TheZ8671 contains two 8-bit programmable counter/tinners 
(TO and T1), each driven by its own 6-bit programmable 
prescaler The T1 prescaler can be driven by internaf or 
external clock sources; however, the TO prescaler is driven 
by the internal clock only. 

The 6-bit prescalers can divide the input frequency of the 
clock source by any number from ,1 to 64. Each prescaler 
drives its counter, which decrements the value (1 to 256) that 
has been loaded into the counter. When the counter reaches 
the end of count, a timer interrupt request— IRQ4 (Tq) or 
IRQ5 (T-|)— is generated. 

The counters can be started, stopped, restarted to continue, 
or restarted from the initial value. The counters can also be 
programmed to stop upon reaching zero (single-pass 



mode) or to automatically reload the initial value and 
continue counting (modulo-n continuous mode). The 
counters, but not the prescalers, can be read any time 
without disturbing their value or count mode. 

The clock source for T1 is user-definable; it can be either the 
internal microprocessor clock (4 MHz maximum) divided by 
four, or an external signal input via Port 3. The Timer Mode 
register configures the external timer input as an external 
clock, a trigger input that can be retriggerable or 
nonretriggerable, or as a gate input for the internal clock. 
The counter/timers can be programmably cascaded by 
connecting the TO output to the input of T1 . Port 3 line P36 
also serves as a timer output (Tqut) through which TO, T1 or 
the internal clock can be output. 



INTERRUPTS 

The Z8671 allows six different interrupts from eight sources: 
the four Port 3 lines P3o-P33, Serial In, Serial Out, and the 
two counter/timers. These interrupts are both maskable and 
prioritized. The Interrupt Mask register globally or 
individually enables or disables the six interrupt requests. 
When more than one interrupt is pending, priorities are 
resolved by a programmable priority encoder that is 
controlled by the Interrupt Priority register 

All Z8671 interrupts are vectored; however, the internal 
UART operates in a polling fashion. To accommodate a 
polled structure, any or all of the interrupt inputs can be 
masked and the Interrupt Request register polled to 
determine which of the interrupt requests needs service. 

The BASIC/Debug Interpreter does not process interrupts. 
Interrupts are vectored through locations in internal ROM 
which point to addresses 1000-1011 h- To process 



interrupts, jump instructions can be entered to the interrupt 
handling routines at the appropriate addresses as shown in 
Table 1 . 

Table 1 . Interrupt Jump Instructions 



0) 

3 



Hex 


Contains Jump Instruction and . 


Address 


Subroutine Address for: 


1000-1002 


IRQO 


1003-1005 


IRQ1 ' 


1006-1008 


IRQ2 


1 009-1 OOB 


IRQ3 


10OC-100E 


IRQ4 


100F-1011 


. IRQ5 
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CLOCK 



The on-chip oscillator has a high-gain, parallel-resonant 
amplifier for connection to a crystal or to any suitable 
external clodk source (XTAL1 = Input, XTAL2 = Output). 

The crystal source is connected across XTAL1 and XTAL2, 
using the recomnnended capacitance (Cl = 15 pf 
maximum) from each pin to ground. The specifications for 
the crystal are as follows: 



AT cut, parallel resonant 
Fundamental type, 8 maximum 
Series resistance, R < 1 00 Q 
8 MHz maximum 



INSTRUCTION SET NOTATION 

Addressing Modes. The following notation is used -to 
describe the addressing modes and instruction operations 
as shown in the instruction summary 

IRR Indirect register pair or indirect working-register 

pair address 

Irr Indirect working-register pair only 

X Indexed address 

DA Direct address 

RA Relative address 

IM Immediate 

R Register or working-register address 

r Working-register address only 

IR Indirect-register or indirect working-register 

address 

Ir Indirect working-register address only 

RR Register pair or working register pair address 

Symbols. The following symbols are used in describing the 
instruction set. 

dst Destination location or contents 

Src Source location or contents 

cc Condition code (see list) 

@ Indirect address prefix 

SP Stack pointer (control registers 254-255) 

PC Program counter 

FLAGS Flag register (control register 252) 

RP Register pointer (control register 253) 

IMR Interrupt mask register (control register 251) 



Assignment of a value is indicated by the symbol "9". For 
example, 

dst ^ dst -I- src 

indicates that the source data is added to the destination 
data and the result is stored in the destination location. The 
notation "addr(n)" is used to refer to bit "n" of a given 
location. For example, 

dst (7) 

refers to bit 7 of the destination operand. 

Flags. Control Register R252 contains the following six 
flags: 

C 

z 
s 

V 
D 
H 



Carry flag 
Zero flag 
Sign flag 
Overflow flag 
Decimal-adjust flag 
Half-carry flag 

Affected flags are indicated by: 

Cleared to zero 

1 Set to one 

* Set or cleared according to operation 

— Unaffected 

X Undefined 
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CONDITION CODES 



Value 


Mnemonic 


Meaning 


Flags Set 




1000 




Always true 


— 




0111 


C 


Carry 


C= 1 




1111 


NC 


No carry 


.0 = 




.0110 


Z 


Zero 


Z= 1 




1110 


NZ 


. Not zero 


Z = 




1101 


PL 


Plus 


s = o 




0101 


Ml 


Minus 


S= 1 




•0100 


OV 


Overflow 


V= 1 




1100 


NOV 


No overflow 


v = o 




0110 


EQ 


Equal 


Z= 1 




1110 


NE 


Not equal 


Z = ' 


\ 


1001 


GE 


Greater than or equal 


(SXORV) = 


0001 


LT 


Less than 


(SXORV) = 1 


C 

1^ 


1010 


GT 


Greater than 


[Z OR (S XOR V)] = 


» 


0010 


LE 


Less than or equal 


[Z OR (S XOR V)] = 1 


s 


1111 


UGE 


Unsigned greater than or equal 


= 


e 


0111 


ULT 


Unsigned less than 


C = 1 


e 


1011 


UGT 


Unsigned greater than 


(0 = OANDZ = 0) = 1 




0011 


ULE , 


Unsigned less than or equal 


(C0RZ) = 1 




0000 




Never true 


— 




INSTRUCTION 


FORMATS 

C 
[ 










OPC 1 CCF, Dl, El, IRET, NOP, 






KCF, RET, SCF 






dst 1 OPC 1 INCr 





ONE-BYTE INSTRUCTION 



OPC MODE 



OR 1 1 1 dst/src 



OR |l 1 1 o| dst 



OPC 


MODE 


dst 


src 



MODE 


OPC 


dst/src 


src/dst 



CLR, CPL, DA, DEC, 
DECW, INC, INCW, POP, 
PUSH, RL, RLC, RR, 
RRC, SRA, SWAP 

JP, CALL (Indirect) 



ADC, ADD, AND, 
CP, OR, SBC, SUB, 
TCM, TM, XOR 



LD, LDE, LDEi, 
LDC, LDCI 



OPC I MODE 



OPC I mode" 



MODE I OPC 



1110 


src 


1110 


dst 



OR |1 1 1 0| dst 



MODE 


OPC 


dst/src 


X 


ADDRESS 



ADC, ADD, AND, CP, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 



ADC, ADD, AND, CP, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 



1110 


src 


1110 


dst 



dst/src OPC 



OR |1 1 1 Oj src I 



dst/CC ] OPC 



DAu 



Two-Byte Instruction 



THREE-BYTE INSTRUCTION 



Figure 1 1 . Instruction Formats 
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INSTRUCTION SUMMARY 



Instruction 
and Operation 


Addr Mode 


Opcode 
Byte 
(Hex) 


Flags Affected 


dst src 


C Z S V D H 


ADCdst.src 

dst — dst + src + C 


(Notel) 


1D 


* * * * * 


ADD dst, src 
dst -^ dst + src 


(Note1) 


on 


* * * * * 


AND dst.src 

dst — dst AND src 


(Notel) 


SD 


- * * 


CALL dst 

SP-SP - 2 
@SP*-PC;PC-dst 


DA 
IRR 


D6 
D4 




CCF 

C - NOT C 




EF 


* 


CLR dst 

dst-0 


R 
IR 


BO 
B1 




COM dst 

dst - NOT dst 


R 
IR 


60 
61 


- * * 


CP dst, src 
dst - src 


(Notel) 


AD 


* * * * 


DA dst 

dst - DA dst 


R 
IR 


40 
41 


* * * X 


DEC dst 

dst - dst - 1 ' 


R 
. IR 


00 
01 


— * * * 


DECW dst 

dst <- dst - 1 


RR 
IR 


80 
81 


— * * * 


Di 

IMR(7)-0 




8F 





DJNZ rdst 
r-r - 1 
ifr^^O • 

PC - PC + dst 
Range: +127, -128 



RA 



El 

IMR(7)-1 



rA 
r = - F 

9F , 



INC dst 


r 


rE 


- * * * — 


dst - dst + 1 




r = 0- F 






R 


20 






IR 


21 





INCW dst RR 

dst — dst + 1 IR~^ 




AO 
A1 




— * * * 


IRET 

FLAGS - @SP; SP - SP + 1 
PC - @SP; SP - SP + 2- IMR (7) 


_ 


BF 

1 




****** 


JPccdst DA 
if cc IS true 
PC -dst IRR 


c 


cD 

= - 

30 


F 





Addr Mode Opcode Flags Affected 

Byte 

dst src (Hex) C Z S V D H 



Instruction 
and Operation 



JRcc.dst 
if cc IS true, 

PC - PC + dst 
Range: +127,-128 



RA 



cB 
c = - F 



LD dst, src 
dst — src 



X 
r 
Ir 
R 
R 
R 
IR 
IR 



Im 
R 
r 



R 
IR 
IM 
IM 
R 



rC 
r8 
r9 
r = - 
C7 
D7 
E3 
F3 
E4 
E5 
E6 
E7 
F5 



LDC dst.src 
dst — src 


r 
Irr 


Irr 
r 


02 
D2 




LDCI dst.src 

dst — src 

r — r + 1 ; rr — rr + 1 


Ir 
Irr 


Irr 
Ir 


03 
D3 




LDE dst.src 
dst — src 


r 
Irr 


Irr 
r 


82 
92 




LDEI dst,src 

dst — src 

r — r + 1 ; rr — rr + 1 


Ir 
Irr 


Irr 
Ir 


83 
93 




NOP 






FF 




OR dst.src 

dst - dst OR src 


(Note 


'1) 


4n 


- * * 


POP dst 

dst-@SP; 
SP-SP + 1 


R 

IR 




50 

51 




PUSH src 

SP-SP- 1;@SP-! 


src 


R 

IR 


70 
71 




RCF 

C-0 






OF 





RET 

PC-@SP;SP-SP4 


- 2 




AF 






R 
IR 




90 

91 




HLdst ^J^^ 


* * * * 




R 

IR 




10 
11 




^LCdstL^j^,^^,^ 


* * * * 




R 
IR 




EO 

El 

/ 




«f^^^^ LtcjL^^ 


* * * * 
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INSTRUCTION SUMMARY (Continued) 



Addr Mode 


Opcode 
Byte 
(Hex) 


Flags Affected 


Instruction 

and Operation dst src 


C Z S V D H 




CO 
C1 




HHCds,L,^^,^^H 


* * * * 


SBC dst, src (Note1) 
dst *- dst ^ src ^ C 


3n 


* * * * 1 * 


SCF 

C-1 


DF 


1 : — 




DO 
Di 




SRAdstL^HTT^R 
^Prr-^ iR 


* * * — 


SRP src Im 

RP ^ src 


31 




SUBdst,src (Note1) 
dst *- dst ^ src 


2n 


* * * * 1 * 


SWAP dst ^=p^^ R 
' 1 ' * ' IR 


FO 
F1 


X * * X 


TCIVIdst.src (Note1) 
(NOT dst) AND src 


en 


- * * 


TlVldst.src (Note1) 
dst AND src 


7n 


- * * 



Instruction 
and Operation 


Addr Mode 


Opcode 
Byte 
(Hex) 


Flags Affected 


dst src 


C Z S V D H 


XORdst.src 
dst*- dst XOR src 


(Note1) 


BD 


- * * 



NOTE: These instructions have an identical set of addressing modes, 

which are encoded for brevity. The first opcode nibble is found in 
the instruction set table above. The second nibble is expressed 
symbolically by a D in this table, and its value is found in the 
following table to the left of the applicable addressing mode pair 
For example, the opcode of an ADC instruction using the 
addressing modes r (destination) and Ir (source) is 13. 



Lower 
Opcode Nibble 



Addr Mode 


dst 


src 


r 
r 


r 
Ir 


R 


-R 


R 


IR 


R 


IM 


IR 


IM 



m 
m 




M 

3 
o 

a 
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REGISTERS 



R240 SIO 
Serial I/O Register 

(FOh; Read/Write) 

I D J Oe I Ds I D4 I D3 I O2 



\Eh} 



- SERIAL DATA (D,, = LSB) 



R244 TO 
Counter/Timer Register 

(F4h; Read/Write) 

|D,|Dg[D5|D4|D3|D2|D,fDn 



To INITIAL VALUE (WHEN WRITTEN) 

-{RANGE: 1-256 DECIMAL 01-00 HEX) 

To CURRENT VALUE (WHEN READ) 



R241 TMR 
Time Mode Register 

(F1h; Read/Write) 



R245 PREO 
Prescaler Register 

(F5h; Write Only) 



Tout MODES 

NOT USED = 00 

To OUT = 01 

T, OUT = 10 

INTERNAL CLOCK OUT « 11 

T,M MODES 

EXTERNAL CLOCK INPUT = 00 

GATE INPUT = 01 

TRIGGER INPUT = 10 

(NONRETRIGGERABLE) 

TRIGGER INPUT ^ 11 
(RETRIQGERABLE) 



(o,- 


DelOs 


D4|D3iD2|D, |Do| 










L 



D«[D3|Da|D, |Do) 



COUNT MODE 
- = To SINGLE-PASS 
1 = To MODULON 



-RESERVED (MUST BE 0) 



PRESCALER MODULO 
-(RANGE: 1-64 DECIMAL 
01-00 HEX) 



R242 T1 
Counter Timer 1 Register 

(F2h; Read/Write) 

I D7 I Dg I D5 I D4 I D3 I D; [ D, I Dp I 



R246 P2M 
Port 2 Mode Register 

(F6h; Write Only) 

I D7 I De [ D5 1 D4 I D3 I D^ I D, I d71 



T, INITIAL VALUE (WHEN WRITTEN) 

-(RANGE 1-256 DECIMAL 01-00 HEX) 

T, CURRENT VALUE (WHEN READ) 



P2o-P2, I/O DEFINITION 
- DEFINES BIT AS OUTPUT 
1 DEFINES BIT AS INPUT 



R243 PRE1 
Prescaler 1 Register 

(F3h; Write Only) 



D4 D3 D2 D J Do 



count mode 
- 1 = t, modulon 
= t, single-pass 

clock source 
_ 1 = t, internal 
= t, external 
timing input 
(t,n) mode 

prescaler modulo 
-(range: 1-64 decimal 

01-00 HEX) 



R247 P3M 
Port 3 Mode Register 

(F7h; Write Only) 



I Dr I De I Ds I D4 



P3 I D2 I Dt I Dp I 



L; 



- RESERVED (MUST BE 0) 

: INPUT 
= DAVO/RI 

P33 = INPUT 

} P33 = INPUT 

RESERVED 



= OUTPUT 
. 5M 



= INPUT (Tim) P36 = OUTP UT (Tq ut) 
= DAV2/RDY2 PSe = RDY2/DAV2 

P37 = OUTPUT 
P37 = SERIAL OUT 



Figure 12. Control Registers 
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REGISTERS 

(Continued) . ' 



R248P01M 
Port Register 

(F8h; Write Only) 



MK 



I4-PO7 MODE 
PUT i= 00 I 



OUTPUT 

INPUT = 01 
A,2-A,5 = 1X 

EXTERNAL 
MEMORY TIMING - 
NORMAL = 
•EXTENDED = 1 



P^I°^|P^I°o| 



T 



PO0-PO3 MODE 

00 = OUTPUT 

01 J= INPUT 
IX = Ag-A,, 

STACK SELECTION 
- = EXTERNAL 
1 = INTERNAL 



- RESERVED (MUST BE 0) 



R252 FLAGS 
Flag Register 

(FCh; Read/Write) 

|D;|D6|D5|D4|D3|D;[d, |Do| 



L 



USER FLAG F1 
-USER FLAG F2 
-HALF CARRY FLAG 
-DECIMAL ADJUST FLAG 
-OVERFLOW FLAG 
-SIGN FLAG 
-ZERO FLAG 
-CARRY FLAG 



•ALWAYS EXTENDED TIMING AFTER RESET 



R249 IPR 
Interrupt Priority Register 

(F9h; Write Only) 



. I D, I De I D5 I'd 



(RQ3, IRQ5 PRIORITY (GROUP A) 

= IRQ5 > IRQ3 - 

1 = mQ3 > IRQ5 

IRQO, IRQ2 PRIORITY (GROUP B) 

= IR02 > IRQO - 

1 = IRQO > IRQ2 

IRQ1, IRQ4 PRIORITY (GROUP C) 

= IRQ1 > IRQ4 - 

1 = IRQ4 > IRQ1 



7007] 



>ter 


REGISTER 
POINTER 


R253 RP 
Register Pointer 

(FDh; Read/Write) 




|D,|De|D5lD,|D,|D,|D,|Do| , 








INTERRUPT GROUP PRIORITY 

RESERVED = 000 

C > A > B = 001 
- A > B > C = 010 


il' 




1 DON'T CARE 


B > C > A - 100 








C > B > A = 101 
B > A > C = 110 
RESERVED = 111 









R250 IRQ 
Interrupt Request Register 

(FAh; Read/Write) 



I D; I Dg I Ds I D4 I D3 I D; I D, I Dp I 
RESERVED (MUST BE 0) ' I 



IRQO = P32 INPUT (Do = IRQO) 

IRQ1 = P33 INPUT 

IRQ2 = P3i INPUT 

IRQ3 = P3o INPUT, SERIAL INPUT 

IRQ4 = To, SERIAL OUTPUT 

IRQ5 = Ti 



R254 SPH 
Stack Pointer 

(FEh; Read/Write) 

|D,|Dg|D5|D4|D3|D;|D, |Do"| 



R251 IMR 
interrupt Mask Register 

(FBh; Read/Write) 

{ D7 I Ds I D5 I D4 I D3 I D; I D^ I Dp I 



1 ENABLES IRQO-IRQS 
(Do = IRQO) 

- RESERVED (MUST BE 0) 
-1 ENABLES INTERRUPTS 



R255 SPL 
Stack Pointer 

(FFh; Read/Write) 

|D7|D6|D5|D4|D3|Da|D, IDqI 



STACK POINTER LOWER 
BYTE (SP0-SP7) 



Figure 12. Control Registers (Continued) 
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OPCODE MAP 



Lower Nibble (Hex) 
7 8 



6,5 


6,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 


6,5 


6,5 


12/10,5 


12/10,0 


6,5 


12/10,0 


6,5 




DEC 


DEC 


ADD 


ADD 


ADD 


ADD 


ADD 


ADD 


LD 


LD 


DJNZ 


JR 


LD 


JP 


INC 




Ri 


iRi 


n.rg 


ri.lr2 


R2.R1 


IR2.R1 


Rl,IM 


IRl.lM 


ri.R2 


r2.Rl 


ri,RA 


ccRA 


ri,iM 


cc,DA 


ri 




6.5 


■ 6,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 
































RLC 


RLC 


ADC 


ADC 


ADC 


ADC 


ADC 


ADC 
































Ri 


IRi 


ri-r2 


ri.lr2 


R2.R1 


IR2.R1 


Rl,IM 


IRl,IM 
































6,5 


6,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 




INC 


INC 


SUB 


SUB 


SUB 


SUB 


SUB 


SUB 
































Ri 


IRi , 


ri/2 


ri.lr2 


R2.R1 


IR2.R1 


Rl,IM 


IRl,IM 






























J 


8,0 


6,1, 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 


JP 


SRP 


SBC 


SBC 


SBC 


SBC 


SBC 


SBC 
































IRRl 


IM 


^^^2 


ri.lr2 


R2.R1 


IR2.R1 


Rl,IM 


IRl,IM 
































8,5 


8,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 




OA 


DA 


OR 


OR 


OR 


OR 


OR 


OR 
































Ri 


IRi 


ri.r2 


'■l.l''2 


R2.R1 


IR2,Ri 


Rl,IM 


-IRi;IM 
























^ 








10,5 


10,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 




POP 


POP 


AND 


AND 


AND 


AND 


AND 


AND 
































Ri 


lRi 


ri.r2 


n.ir2 


R2.R1 


IR2.R1 


Rl,IM 


IRl,IM 
































6,5 


6,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 




COM 


COM 


TCM 


TCM 


TCM 


TCM 


TCM 


TCM 
































Ri 


IRi 


ri.r2 


ri.lr2 


R2.R1 


IR2,Ri 


Rl,IM 


IRl,IM 
































10/12,1 


12/14,1 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 


PUSH 


PUSH 


TM 


TM 


TM 


TM 


TM 


TM 
































R2 


IR2 


ri-r2 


ri.lr2 


R2.R1 


IR2,Ri 


Rl.lM 


IRl,IM 
































10,5 


10,5 


12,0 


18,0 










6,1 


DECW 


DECW 


LDE 


LOEI 






































Dl 


RRl 


IRi 


ri,lrr2 


Iri,lrr2 








































6,5 


6,5 


12,0 


18,0 










6,1 


RL 


RL 


LDE 


LDEI 






































El 


Ri 


IRi 


r2,lrri 


Ir2,lrri 








































10,5 


10,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 


14,0 


INCW 


INCW 


CP 


CP 


CP 


CP 


CP 


CP 






























RET 


RRl , 


IRi 


ri,r2 


ri,lr2 


R2.R1 


IR2,Ri 


Rl,IM 


IRl.lM 
































6,5 


6,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 


16,0 


CLR 


CLR 


XOR 


XOR 


XOR 


XOR 


XOR 


XOR 






























IRET 


Ri 


IRi 


ri.r2 


ri,lr2 


R2.R1 


IR2.R1. 


R^.IM 


IRl,IM 
































6,5 


6,5 


12,0 


18,0 








10,5 


6,5 


RRC 


RRC 


LDC 


LDCI 








LD 






























RCF 


Ri 


IRi 


ri,lrr2 


Iri,lrr2 








ri,x,R2 
































6,5 


6,5 


12,0 


18,0 


20,0 




20,0 


10,5 


6,5 


SRA 


SRA 


LDC 


LDCI 


CALL* 




CALL 


LD 






























SCF 


Ri 


IRi 


r2:irri 


Ir2,lrri 


IRRl 




DA ■ 


F2.x,Ri 
































6,5 


6,5 




6,5 


10,5 


10,5 


10,5 


10,5 


6,5 


RR 


RR 




LD 


LD 


LD 


LD 


LD 






























CCF 


Ri 


IRi 




ri,IR2 


R2.R1 


IR2.R1 


Rl,1M 


IRl,IM 
































- 85 


8.5 




6,5 




10,5 






6,0 


SWAP 


SWAP 




LD 




LD 


































NOP 


Ri 


IR1 




Iri.r2 




R2,lRi 






1 


r 


) 


r 


\ 


r 


1 


r 


1 


r 


1 


1 


\ 


1 





LOWER 
OPCODE 
NIBBLE 



Bytes per Instruction 



EXECUTION 
CYCLES 



v:^ 



PIPELINE 
CYCLES 



UPPER 

OPCODE - 

NIBBLE 



10,5 
CP 

R2.R1 



FIRST 
OPERAND 



A^ 



SECOND 
OPERAND 



Legend: 

R = 8-bit address 
r = 4-bit address 
R-l orr-i = Dst address 
R2 or r2 = Src address 

Sequence: 

Opcode, First Operand, Second Operand 

NOTE: The blank areas are not defined 



■2-byte instruction fetch cycle appears as a 3-byte instruction 
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ABSOLUTE MAXIMUM RATINGS 

Voltages on all pins with respect 

toGND -0.3V to +7.0V 

Operating Annbient 

Temperature See Ordering Information 

Storage Temperature -65°Cto +150°C 

STANDARD TEST CONDITIONS 

The DC characteristics listed below apply for the following 
standard test conditions, unless otherwise noted. All 
voltages are referenced to GND. Positive current flows into 
the referenced pin. 

Standard conditions are: 

■ + 4.75V <Vcc<+ 5.25V 

■ GND = OV 

■ 0°C<Ta< +70°C 



Stresses greater than those listed under Absolute Maximum Ratings may 
cause permanent damage to the device. This is a stress rating only; 
operation of the device at any condition above those indicated in the 
operational sections of these specifications is not implied. Exposure to 
absolute maximum rating conditions for extended periods may affect 
device reliability. 



The Ordering Information section lists package temperature 
ranges and product numbers. Package drawings are in the 
Package Information section. Refer to the Literature List for 
additional documentation. 



FROM OUTPUT , 
UNDER TEST ^ 




Figure 13. Test Load 1 



DC CHARACTERISTICS 


Symbol 


Parameter 


Min 


Max 


Unit 


Condition 


VCH 


Clock Input High Voltage 


3.8^ 


Vcc 


V 


Driven by External Clock Generator 


VCL 


Clock Input Low Voltage 


-0.3 


• 0.8 


V 


Driven by External Clock Generator 


V|H 


Input High voltage 


2.0 


Vcc 


^J 




V|L 


Input Low Voltage 


-0.3 


0.8 


V 




Vrh 


Reset Input High Voltage 


3.8 


Vcc 


V 




Vrl 


Reset Input Low Voltage 


-0.3 


0.8 


V 




VOH 


Output High Voltage 


2.4 




\/ 


lOH = -250mA , 


Vol 


Output Lpw Voltage 




0.4 


V 


Iql = + 2.0 mA 


l|L 


Input Leakage 


-10 


10 


mA 


OV<V||M< + 5.25V 


lOL 


Output Leakage 


-10 


10 , 


mA 


OV<V(N< + 5.25V 


l|R ' 


Reset Input Current 




-50 


mA 


Vcc = + 5.25V Vrl = OV 


Ice 


Vcc Supply Current 




180 


mA 
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X 



X 



-*<J2>^ 



PORT 0, 
DM 



X 



-Ki> 



~\^' 



DS 

(READ) 



DS 

(WRITE) 



A0-A7 ' ^ 



=% 



<D- 



^ D0-D7IN J ^' 



-® — 4\ 



-©- 



-©- 



3C3ZDC 



D0-D7 OUT 



n: 



-<!>- 



f 



-•-©-► 



-Ki]> 



K 



K 



-*-®-*- 



Figure 1 6. External I/O or Memory Read/Write 








AC CHARACTERISTICS 

External I/O or Memory ReadA/Vrite Timing 


No. Symbol Parameter 


Min 


Max 


Notes*t*» 



TdA(AS) 

TdAS(A) 

TdAS(DR) 

TwAS 

TdAz(DS) 



1 
2 
3 
4 
5 

6 — TwDSR 

7 TwDSW 

8 TdDSR(DR) 

9 ThDR(DS) 

10 TdDS(A) ' 

11 TdDS(AS) 

12 ~ TdR/W(AS) - 
13, TdDS(R/W) 

14 TdDW(DSW) 

15 fdDS(DW) 

16 TdA(DR) 

17 TdAS(DS) 



Address Valid to AS t Delay 

AS t to Address Float Delay 

JEUo Read Data Required Valid 

AS Low Width 

Address Float to DS i 
- DS (Read) Low Width 

DS (Write) Low Width 

DS 4 to Read Data Required Valid 

Read Data to HS T Hold Time 

DS T to Address Active Delay 

DS t to AS i Delay 
■ R/W Valid to JS t Delay -— 

nSt to R/W Not Valid 

Write Data Valid to DS (Write) i Delay 

DS t to* Write Data Not Valid Delay 

Address Valid to Read Data Required Valid 

ASttoDSiDelay 



35 
45 

55 

•185- 
110 


45 
55 
-30- 
35 
35 
45 

55 



220 



130 



255 



2,3 
2,3 
1,2,3 
1,2,3 

"1,2,3 
1,2,3 
1,2,3 

2,3 
2.3 
-2,3 
2,3 
2,3 
2,3 
1,2,3 
2,3 



NOTES: 

1 . When using extended memory timing add 2 TpC. 

2. Timing numbers given are for minimum TpC. 

3. See clock cycle time dependent characteristics table. 



t Test Load I. 

° All timing references use 2.0 V for a logic "1" and 0.8 V for d logic "0". 

* All units in nanoseconds (ns). 
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■<L>- 



-©-*- 



Tin 



■^ — ^^' — v^ — ^ 

\ )^~\ 



IRQn 



M © * 






Figure 17. Additional Timing 








AC CHARACTERISTICS 

Additional Timing 


No. Symbol Parameter 




Min 


Max 


Notes* 



1 TpC Input Clock Period 

2 TrCTfC Clock Input Rise And Fall Times 

3 TwC Input Clock Width 

4 TwTinL Time Input Low Width 

5 — TwTinH Timer Input High Width 

6 TpTin Timer Input Period 

7 TrTin,TfTin Timer Input Rise And Fall Times 
8a TwIL Interrupt Request Input Low Time 
8b TwIL Interrupt Request Input Low Time 

9 TwIH Interrupt Request Input High Time 



80 


1000 


1 




15 


1 


26 




1 


70 




2 


sJipv-/ 




A 


8TpC 




2 




100 


2 


70 




2,3 


3TpC 




2,4 


STpC 




2,3 



NOTES: 

1 . Clock timing references 
a logic "0". 

2. Timing reference uses 2. 
a logic "0". 



uses 3.8 V for a logic "T'.and 0.8 V for 
V for a logic " 1 " and 0.8 V for 



3. Interrupt request via Port 3 (P3i-P33). 

4. Interrupt request via Port 3 (P3o). 
* Units in nanoseconds (ns). 



Ao-Aio 



D0-D7 



X 



■<!>- 



ADDRESS VALID 



X 



DATA IN VALID 



'£ 



:c 



Figure 18. IVIemory Port Timing 








AC CHARACTERISTICS 

Memory Port Timing 


No. Symbol Parameter 


Min 


Max 


Notes* 


1 TdA(DI) Address Valid to Data Input Delay 

2 ThDI( A) Data In Hold time 





320 


1,2 
1 



NOTES: 

1. Test Load 2. 

2. This is a Clock-Cycle-Dependent parameter. For clock frequencies 
other than the maximum, use the following formula: 5 TpC - 95 



'Units are nanoseconds unless otherwise specified. 
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DAV 

(INPUT) 



RDY 

(OUTPUT) 



X 



©- 



DATA IN VALID 



\ 



-(D- 



&- 



\ 



^ 

^ 



-<D- 



/ 



Figure 18a. Input Handshake 



DATA OUT 


) 


I 

L 


DATA OUT VALID 
















^-<8^-^ 


L J, 












DAV 

(OUTPUT) 




' 


(^ 












r 


/TN 




1 










'' 


^ 




-® 


W 






RDY 

(INPUT 


Figure 18b. Output 


it— ^ 


r 








Handsh 


ike 












AC CHARACTERISTICS 

Han(dshake Timing 


No. Symbol 


Parameter 








Min 


Max 




Notes'* 


1 TsDI(DAV) Data In Setup Time 

2 ThDI(DAV) Data In Hold time 

3 TwDAV Data Available Width 

4 TdDAVIf(RDY) DAV i Input to RDY i 

5 — TdDAVOf (RDY) D^ i Output to RDY 

6 TdDAVIr(RDY) t)AV t Input to RDY t 

7 TdDAVOr(RDY) DAV t Output to RDY 

8 TdDO(DAV) Data Out to DAV i Del 

9 TdRDY(DAV) Rdy i Input to DM T I 


Delay 









160 
120 


120 






1,2 

-1,3 

1,2 

1,3 

1 
1 


Delay 
T Delay 
ay 
Delay 










30 




120 
140 






NOTES: 

1. Test load 1 

2. Input handshake 

3. Output handshake 

t All timing references use 
a logic "0". 


2.0 V for a logic "1" and 0.8 V lor 




* Units in nanoseconds (ns). 












CLOCK CYCLE TIME-DEPENDENT CHARACTERISTICS 

Z8671-8 
Number Symbol Equation Number 


Symbol 




Z8671-8 
Equation 




1 
2 
3 
4 
6 


TdA(AS) TpC - 75 
TdAS(A) TpC - 55 
TdAS(DR) 4TpC- 140* 
TwAS TpC - 45 
TwDSR 3TpC-125* 




13 
14 
15 
16 
17 


TdDS(R/W) 

TdDW(DSW) 

TdDS(DW) 

TdA(DR) 

TdAS(DS) 




TpC- 
TpC- 
TpC- 
5TpC- 
TpC- 


-65 

- 75 

- 55 
215 

-45 


* 


7 

8 

10 

11 

12 


TwDSW 2TpC-90* 
TdDSR(DR) 3TpC - 175* 
Td(DS)A TpC - 55 
TdDS(AS) TpC - 55 
TdR/W(AS) , TpC - 75 


















* Add 2TpC when using extended memory timing 
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^ZiKB 



Product Specification 



Z8681/82 Z8® 
ROMIess MCU 



June 1987 



FEATURES 

■ Complete microcomputer, 24 I/O lines, and up to 64K 
bytes of addressable external space each for program 
and data memory. 

■ 143-byte register file, including 124 general-purpose 
registers, 3 I/O port registers, and 1 6 status and control 
registers. ^ 

■ Vectored, priority interrupts for I/O, counter/timers, and 
UART. 

■ On-chip oscillator that accepts crystal or external clock 
drive. 



Full-duplex UART and two programmable 8-bit 
counter/timers, each with a 6-bit programmable 
prescaler. 

Register Pointer so that short, fast instructions can 
access any one of the nine working-register groups. - 

Single + 5V power supply— all I/O pins TTL compatible. 

Z8681/82 available In 8 MHz. Z8681 also available 
in 12 and 16 MHz. 



GENERAL DESCRIPTION 



The Z8681 and Z8682 are ROMIess versions of the Z8 
single-chip microcomputer. The Z8682 is usually more cost 
effective. These products differ only slightly and can be 
used interchangeably with proper system design to provide 
maximum flexibility in meeting price and delivery needs. 



The Z8681/82 offers all the outstanding features of the Z8 
family architecture except an on-chip program ROM. Use of 
external memory rather than a preprogrammed ROM 
enables this Z8 microcomputer to be used in low volume 
applications or where code flexibility is required. 



TIMING 

AND 

CONTROL 



PORTO 

(NIBBLE 
PROGRAMMABLE) 

I/O OR A8-Ai5 



PORT 1 

(BYTE 
PROGRAMMABLE) 

AD0-AD7 



RESET 
R/W 



AS 



POo 



PO1 
PO2 
PO3 
PO4 
PO5 Z8681/82 ^^' 



+ 5V 

GND 

XTAL1 

XTAL2 

P2o 

P2i 

P22 
P23 



PI7 



MCU 



P26 
P27 

P3o 
P3i 



P33 
P34 
P35 



PORT 2 

(BIT PRO- 
GRAMMABLE) 



PORT 3 

SERIAL AND 
PARALLEL I/O 
AND CONTROL 









Ky 




+ 5V 


L 


1 


^^ 40 


JP36 


XTAL2 


C 


2 


39 


3p3. 


XTAL1 


L 


3 


38 


]P27 


P37 


L 


4 


37 


lP2, 


P3o 


C 


5 


36 


Dp2b 


RESET 


L 


6 


35 


JP2. 


R/W 


L 


7 


34 
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Figure 1 . Pin Functions 



Figure 2a. 40-pin Dual-ln-Line Package (DIP), 
Pin Assignments 
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The Z8681/82 can provide up to 16 output address lines, 
thus permitting an address space of up to 64K bytes of data 
or program memory. Eight address outputs (AD0-AD7) are 
provided by a multiplexed, 8-bit, Address/Data bus. The 
remaining 8 bits can be provided by the software 
configuration of Port to output address bits A8-A15. 

Available address space can be doubled (up to 1 28K bytes 
for the Z8681 and 124K bytes for the Z8682) by 
programming bit 4 of Port 3 (P34) to act as a data memory 
select output (DM). The two states of DM together with the 
1 6 address outputs can define separate data and memory 
address spaces of up to 64 K/62 Kbytes each. 



There are 143 bytes of RAM located on-chip and organized 
as a register file of 1 24 general-purpose registers, 1 6 control 
and status registers, and three I/O port registers. This 
register file can be divided into nine groups of 16 working 
registers each. Configuring the register file in this manner 
allows the use of short format instructions; in addition, any of 
the individual registers can be accessed directly. 

The pin functions and the pin assignments of the 
Z8681/82 40- and 44-pin packages are illustrated in 
Figures 1 and 2, respectively. 
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Figure 2b. 44-pin Chip Carrier, 
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ARCHITECTURE 



Z8681/82 architecture is characterized by a flexible I/O 
scheme, an efficient register and address space structure 
and a number of ancillary features that are helpful in many 
applications. 

Microcomputer applications demand powerful I/O 
capabilities. The Z8681/82 fulfills this with 24 pins available 
for input and output. These lines are grouped into three 
ports of eight lines each and are configurable under 
software control to provide timing, status signals, serial' or 
parallel I/O with or without handshake, and an Address bus 
for interfacing external memory 

Three basic address spaces are available: program 



memory, data memory and the register file (internal). The 
143-byte random-access register file is composed of 124 
general-purpose registers, three I/O port registers, and 16 
control and status registers. 

To unburden the program from coping with real-time 
problems such as serial data communication and 
counting/timing, an asynchronous receiver/transmitter 
(DART) and two counter/timers with a large number of 
user-selectable modes are offered on-chip. Hardware 
support for the DART is minimized because one of the 
on-chip timers supplies the bit rate. Figure 3 shows the 
Z8681 /82 block diagram. 



PIN DESCRIPTION 

AS. Address Strobe (output, active Low). Address Strobe is 
pulsed once at the beginning of each machine cycle. 
Addresses output via Port 1 for all external program or data 
memory transfers are valid at the trailing edge of AS. 

DS. Data Strobe (output, active Low). Data Strobe is 
activated once for each external memory transfer 

POo-P07, P2o-P27, P3o-P37. I/O Port Lines (input/outputs, 
TTL-compatible). These 24 lines are divided into three 8-bit 
I/O ports that can be configured under program control for 
I/O or external memory interface (Figure 3). 

PI0-PI7. Address/Data Port (bidirectional). Multiplexed 
address (A0-A7) and data (D0-D7) lines used to interface with 



program and data memory 



RESET . Reset (input, active Low). RESET initializes the 
Z8681/82. After RESE T the Z 8681 is in the extended 
memory mode. When RESET is deactivated, program 
execution begins from program location OOOCh for the 
Z8681 and 081 2h for the Z8682. 

R/W. Read/Write (ouiput). R/Wis Low when the Z868 1/82 is 
writing to external program or data memory 

XTAL1, XTAL2. Crystal 1, Crystal 2 (time-base input and 
output). These pins connect a parallel-resonant crystal to the 
on-chip clock oscillator and buffer 



SUMMARY OF Z8681 AND Z8682 DIFFERENCES 



Feature 



Z8681 



Z8682 



Address of first instruction executed after Reset 

Addressable memory space 

Address of interrupt vectors 

Reset input high voltage 

Port configuration after Reset 

External memory timing start-up configurations 
Interrupt vectors 



Interrupt response time 
* 8.0V V||M max. 



12 

0-64K 

0-11 

TTL levels * 

Input, float after reset. Can be 
programmed as Address bits. 

Extended Timing 

2 byte vectors point directly to service 
routines. 

26 clocks 



2066 

2K-64K 

2048-2065 

7.35-8.0V 

Output, configured as Address bit 

A8-Ai5- 

Normal Timing 

2 byte vectors in internal ROM point to 3 
byte Jump instructions, which point to 
service routines. 

36 clocks 
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ADDRESS SPACES 



Program Memory*. The Z8681/82 addresses 64K/62K 
bytes of external program memory space (Figure 4). 

For the Z8681, the first 12 bytes of program memory are 
reserved for the interrupt vectors. These locations contain 
six 16-bit vectors that correspond to the six available 
interrupts. Program execution begins at location OOOCh 
after a reset. 

The Z8682 has six 24-bit interrupt vectors beginning at 
address 0800h. The vectors consist of Jump Absolute 
instructions. After a reset, program execution begins at 
location 081 2h for the Z8682. 

Data Memory* . The Z8681 /82 can address 64K/62K Iqytes 
of external data memory. External data memory may be 
included with or . separated from the external program 
memory space. DM, an optional I/O function that can be 
programmed to appear on pin P34, is used to distinguish 
between data and program memory space. 

Register File. The 143-byte register file includes three I/O 



port registers (RO, R2, R3), 124 general-purpose registers 
(R4-R1 27) and 1 6 control and status registers (R240-R255). 
These registers are assigned the address locations shown in 
Figure 5. 

Z8681/82 instructions can access registers directly or 
indirectly with an 8-bit address field. This also allows short 
4-bit register addressing using the Register Pointer (one of 
the control registers). In the 4-bit mode, the register file is 
divided into nine working-register groups, each occupying 
16 contiguous locations (Figure 5). The Register Pointer 
addresses the starting location of the active working-register 
group (Figure 6), 

Stacks. Either the internal register file or the external data 
memory can be used for the stack. A 16-bit Stack Pointer 
(R254 and R255) is used for the external stack, which can 
reside anywhere in data memory. An 8-bit Stack Pointer 
(R255) is used for the internal stack that resides within the 
1 24 general-purpose registers (R4-R1 27). 
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Figure 4. Z8681/82 Program Memory Map 



*This feature differs in the Z8681 and Z8682. 
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DEC 
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Figure 5. The Register File 



Figure 6. Tlie Register Pointer 



SERIAL INPUT/OUTPUT 



Port 3 lines P3o and PSy can be,programme(d as serial I/O 
lines for full-(juplex serial asynchronous receiver/transmitter 
operation. The bit rate is controlled by Counter/Tinner 0. 



The Z8681/82 automatically ad(ds a start bit and two stop 
bits .to transnriitted data (Figure 7). Odd parity is also 
available as an option. Eight data bits are always 



transmitted, regardless of parity selection. If parity is 
enabled, the eighth data bit is used as the odd parity bit. An 
interrupt request (IRQ4) is generated on all transmitted 
characters. 

Received data must have a start bit, eight data bits, and at 
least one stop bit. If parity is on, bit 7 of the received data is 
replaced by a parity error flag. Received characters 
generate the IRQ3 interrupt request. 
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Figure 7. Serial Data Formats 
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COUNTER/TIMERS 



The Z8681/82 contains two 8-bit programmable 
counter/timers (Tq and T-i), each driven by its own 6-bit 
programmable prescaler. The Ti prescaler can be driven by 
internal or external clock sources; however, the Tq prescaler 
is driven by the internal clock only. 

The 6-bit prescalers can divide the input frequency of the 
clock source by any number from 1 to 64. Each prescaler 
drives its counter, which decrements the value (1 to 256) that 
has been loaded into the counter. When the counter reaches 
the end of count, a timer interrupt request— IRQ4 (Tq) or 
IRQ5 (T-i)— is generated. 

The counters can be started, stopped, restarted to continue, 
or restarted from the initial value. The counters can also be 
programmed to stop upon reaching zero (single-pass 



mode) or to automatically reload the initial value and 
continue counting (modulo-n continuoU'S mode). The 
counters, but not the prescalers, can be read any time 
without disturbing their value or count mode. 

The clock source for Ti is user-definable; it can be either the 
internal microprocessor clock divided by four, or an external 
signal input via Port 3. The Timer Mode register configures 
the external timer input as an external clock, a trigger input 
that can be retriggerable or nonretriggerable, or as a gate 
input for the internal clock. The counter/timers can be 
programmably cascaded by connecting the Tq output to the 
input of Ti. Port 3 line P36 also serves as a timer output 
(Tout) through which Tq, Ti or the internal clock can be 
output. 



I/O PORTS 



The Z8681/82 has 24 lines available for input and output. 
These lines are grouped into three ports of eight lines each 
and are configurable as input, output or address. Under 
software control, the ports can be programmed to provide 



address outputs, timing, status signals, serial I/O, and 
parallel I/O with or without handshake. All ports have active 
pull-ups and pull-downs compatible with TTL loads. 



Port 1 is a dedicated Z-BUS compatible memory interface. 
The operations of Port 1 are supported by the Address 
Strobe (AS) and Data Strobe (PS) lines, and by the 
Read/Write (R/W) and Data Memory (DM) control lines. The 
low-order program and data memory addresses (A0-A7) are 
output through Port 1 (Figure 8) and are multiplexed with 
data in/out (D0-D7). Instruction fetch and data memory 
read/write operations are done through this port. 

Port 1 cannot be used as a register nor can a handshake 
mode be used with this port. 

Both the Z8681 and Z8682 wake up with the 8 bits of Port 1 
configured as address outputs for external memory. If more 
than eight address lines are required with the Z8681, 
additional lines can be obtained by programming Port bits 
as address bits. The least-significant four bits of Port can 



be configured to supply address bits As-A-n for 4K byte 
addressing or both nibbles of Port can be configured to 
supply address bits A8-A-15 for 64K byte addressing. 



^ 



Z8681/82 
MCU 



PORT 1 

(I/O OR AD0-AD7 

TO EXTERNAL 



Figure 8. Port 1 



Port 0* can be programmed as a nibble I/O port, or as an 
address port for interfacing external memory (Figure 9). 
When used as an I/O port. Port can be placed under 
handshake control. In this configuration, Port 3 lines P32 
and P35 are used as the handshake controls DAVq and 
RDYq. Handshake signal assignment is dictated by the I/O 
direction of the upper nibble PO4-PO7. 

For external memory references. Port can provide address 
bits As-A-ii (lower nibble) or A8-A15 (lower and upper 
nibbles) depending on the required address space. If the 
address range requires 12 bits or less, the upper nibble of 
Port can be programmed independently as I/O while the 
lower nibble is used for addressing. 

In the Z8681 *, Port lines float after reset; their logic state is 
unknown until the execution of an initialization routine that 
configures Porto. 
*This feature differs in the Z8681 and Z8682. 



Such an initialization routine must reside within the first 256 
bytes of executable code and must be physically mapped 
into memory by forcing the Port address lines to a known 
state (Figure 10). The proper port initialization sequence is: 

1. Write initial address (As-A-is) of initialization routine to 
Port address lines. 

2. Configure Port Mode register to output A8-A15 (or 
A8-A11). 

To permit the use of slow memory, an automatic wait mode of 
two oscillator clock cycles is configured for the bus timing of 
the Z8681 after each reset. The initialization routine could 
include reconfiguration to eliminate this extended timing 
mode. 



55 



The following example illustrates the manner in which an 
initialization routine can be mapped in a Z8681 system with 
4K of memory. 

Example. In Figure 10, the initialization routine is nriapped to 
the first 256 bytes of program memory. Pull-down resistors 
maintain the address lines at a logic level when these lines 
are floating. The leakage current caused by fanout must be 
taken into consideration when selecting the value of the 
pulldown resistors. The resistor value must be large enough 
to allow the Port output driver to pull the line to a logic 1. 
Generally, pulldown resistors are incompatible with TTL 
loads. If Port drives into TTL input loads (Ilow = 1 -6 mA) 
the external resistors should be tied toVcc and the 
initialization routine put in address space FFOOh-FFFFh- 

In the Z8682*, Port lines are configured as address lines 
As-A-js after a Reset. If one or both nibbles^re needed for 



I/O operation, they must be configured by writing to the Port 
Mode register. The Z8682 is in the fast memory timing 
mode after Reset, so the initialization routine must be in fast 
memory. 
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Figure 10. Port Address Lines Tied to Logic 



Port 2 bits can be programmed independently as input or 
output (Figure 11). This port is always available for I/O 
operations. In addition, Port 2 can be configured to provide 
open-drain outputs. 

Like Port 0, Port 2 may also be placed under handshake 
control. In this configuration, Port 3 li nes P3i and P3q are 
used as the handshake controls lines DAV2 and RDY2. The 
handshake signal assignment for Ports lines P3-| and P36 is 
dictated by the direction (input or output) assigned to bit 7 of 
Port 2. 
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Figure 1 1 . Port 2 



Port 3 lines can be configured as I/O or control lines (Figure 
12). In either case, the direction of the eight lines is fixed as 
four input (P3o-P33) and four output (P34-P37). For serial I/O, 
lines P3o and P3j are programmed as serial in and serial 
out, respectively. 

Port 3 can also provide the following control functions: 
handshake for Ports and 2 (DAV and RDY); four external 
interrupt request signals (IRQ0-IRQ3); timer input and 
output signals (Tin and Tqut) arid Data Memory Select 
(DM). 
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Figure 12. Ports 



*This feature differs in the Z8681 and Z868?. 
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INTERRUPTS* 



The Z8681/82 allows six different interrupts from eight 
sources: the four Port 3 lines PSq-PSs, Serial In, Serial Out, 
and the two counter/timers. These interrupts are both 
maskable and prioritized. The Interrupt Mask register 
globally or individually enables or disables the six interrupt 
requests. When more than one interrupt is pending, 
priorities are resolved by a programmable priority encoder 
that is controlled by the Interrupt Priority register. 

All Z8681 and Z8682 interrupts are vectored through 
locations in program memory. When an interrupt request is 
granted, an interrupt machine cycle is entered. This disables 
all subsequent interrupts, saves the Program Counter and 
status flags, and accesses the program memory vector 
location reserved for that interrupt. In the Z8681, this 
memory location and the next byte contain the 16-bit 
address of the interrupt service routine for that particular 
interrupt request. The Z8681 takes 63 crystal cycles to 
enter an interrupt subroutine. 

The Z8682 has a small internal ROM that contains six 2-byte 
interrupt vectors pointing to addresses 2048-2065, where 
3-byte jump absolute instructions are located (Figure 4 and 
Table 1). These jump instructions each contain a 1-byte 



opcode and a 2-byte starting address for the interrupt 
service routine! 



Table 1 . Z8682 Interrupt Processing 



Hex 


Contains Jump Instruction and 


Address 


Subroutine Address For 


800--802 


IRQO 


803-805 


IRQ1 


806-808 


IRQ2 


809-80B 


IRQ3 


80C-80E 


IRQ4 


80F-81 1 


IRQ5 



Polled interrupt systems are also supported. To 
accommodate a polled structure, any or all of the interrupt 
inputs can be masked and the Interrupt Request register 
polled to determine which of the interrupt requests needs 



CLOCK 



The on-chip oscillator has a high-gain, parallel-resonant 
amplifier for connection to a crystal or to any suitable 
external clock source (XTAL1 = Input, XTAL2 = Output). 

The crystal source is connected across XTAL1 and XTAL2, 
using the recommended capacitance (Cl = 15 pf 
maximum) from each pin to ground. The specifications for 
the crystal are as follows: 



■ AT cut, parallel-resonant 

■ Fundamental type 

■ Series resistance, Rg < 1 0OQ 

■ For Z8682, 8 MHz maximum 

■ For Z8681-12. 16 MHz maximum 



Z8681/Z8682 INTERCHANGEABILITY 



Although the Z8681 and Z8682 have minor differences, a 
system can be designed for compatibility with both 
ROMIess versions. To achieve interchangeability, the design 
must take into account the special requirements of each 
device in the external interface, initialization, and memory 
mapping. 



External Interfac e. The Z8682 requires a 7.5V positive 
logic level on the RESET pin for at least 6 clock periods 
immediately following reset, as shown in Figure 13. The 
Z8681 requires a 3.8V or hi gher po sitive logic level, but is 
compatible with the Z8682 RESET waveform. Figure 14 
shows a simple circuit for generating the 7.5V level. 
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Figure 13. Z8682 RESET Pin Input Waveform 

*This feature differs in the Z8681 and Z8682. 
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Figure 14. RESET Circuit 
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Initialization. The Z8681 wakes up after reset with Port 
configured as an input, which means Port lines are floating 
in a high-impedance state. Because of this pullup or 
pulldown, resistors must be attached to Port lines to force 
them to. a valid logic level until Port is configured as an 
address port. 

Port initialization is discussed in the section on ports. An 
example of an initialization routine for Z8681/Z8682 
compatibility is shown in Table 2. Only the Z8681 need 
execute this program. 

Table 2. Initialization Routine 

Address Opcodes Instruction Comments 

OOOC E6 00 00 LDPO#%00 Set As-AistoO. 

OOOF E6F8 96 LDP01M#%96 Configure Port as 

A8-A-I5. Eliminate 
extended memory 
timing. 



0012 8D0812 UPSTART 
ADDRESS 



Execute application 
program. 



65536 


APPLICATION 
PROGRAM 


2066 


A.P. PROG START ADDRESS 


2063 


JP IRQ5 


2060 


JP IRQ4 


2057 


JPIRQ3 


2054 


JP IRQ2 


2051 


JP iR01 


2048 


JP IRQO 


2047 
21 


NOT USED 
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15 
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Figure 15. Z8681/82 Logical Program Memory Mapping 
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Memory Mapping. The Z8681 and Z8682 lower memory 
boundaries are located at and 2048, respectively. A single 
program ROM can be used with either product if the logical 
program memory map shown in Figure 15 is followed. The 
Z8681 vectors and initialization routine must be starting at 



address and the Z8682 3-byte vectors (jump instructions) 
must be at address 2048 and higher Addresses in the range 
21-2047 are not used. Figure 16 shows practical schemes 
for implementing this memory map using 4K and 2K ROMs. 
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b. Logical to Physical Memory Mapping for 2K ROM 
Figure 16. Practical Schemes for Implementing Z8681 and Z8682 Compatible Memory Map 
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INSTRUCTION SET NOTATION 



Addressing Modes. The following notation is used to 
describe the addressing modes and instruction operations 
as shown in the instruction summary. 

IRR Indirect register pair or indirect working-register 

pair address 

Irr Indirect working-register pair only 

X Indexed address 

DA Direct address 

RA Relative address 

IM Immediate 

R Register or working-register address 

r Working-register address only 

IR Indirect-register or indirect working-register 

address 

Ir Indirect working-register address only 

RR Register pair or working register pair address 

Symbols. The following symbols are used in describing the 
instruction set. 

dst Destination location or contents 

src Source location or contents 

cc Condition code (see list) 

@ Indirect address prefix 

SP Stack pointer (control registers 254-255) 

PC Program counter 

FLAGS Flag register (control register 252) 

RP Register pointer (control register 253) 

IMR Interrupt mask register (control register 251 ) 



Assignment of a value is indicated by the symbol "^^'. 
example, 

dst *- dst -I- src 



For 



indicates that the source data is added to the destination 
data and the result is stored in the destination location. The 
notation "addr(n)" is used to refer to bit "n" of a given 
location. For example, 

dst (7) 

refers to bit 7 of the destination operand. 

Flags. Control Register R252 contains the following six 
flags: 

C 

z 
s 

V 
D 
H 



Carry flag 
Zero flag 
Sign flag 
Overflow flag 
Decimal-adjust flag 
Half-carry flag 

Affected flags are indicated by: 

Cleared to zero 

1 Set to one 

* Set or cleared according to operation 

— Unaffected 

X Undefined 



CONDITION CODES 



Value 


Mnemonic 


Meaning 




Flags Set 


1000 




Always true 


' — 




0111 


c 


Carry 


C= 1 


' 


1111 


NO 


No carry 


C = 




0110 


Z 


Zero 


Z= 1 




1110 


NZ 


Not zero 


Z = 




1101 


PL 


Plus 


8 = 




0101 


Ml 


Minus 


8= 1 




0100 


OV 


Overflow 


V= 1 




1100 


NOV 


No overflow 


V = 




0110 


EQ 


^ Equal 


Z= 1 




1110 


NE 


Not equal 


Z = 




1001 


GE 


Greater than or equal 


(8X0RV) 


= 


0001 


LT 


Less than 


(8X0RV) 


= 1 


1010 


GT 


Greater than 


[ZOR(8XORV)] = 


0010 


LE 


Less than or equal 


[ZOR(SXORV)] = 1 


1111 


UGE. 


Unsigned greater than or equal 


C = 




0111 


ULT 


Unsigned less than 


C = 1 




1011 


UGT 


Unsigned greater than 


(C = OANDZ.= 0) = 1 


0011 


ULE 


Unsigned less than or equal 


(CORZ) = 


= 1 


0000 




Never true 
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INSTRUCTION FORMATS, 



I dst I OPC I 



CCF, Dl, El, IRET, NOP, 
RCF, RET, SCF 



One-Byte Instruction 



OPC ] MODE i CLR, CPL, DA, DEC, 

hI^ no l-t i I n l ric«/cro I DECW, INC, INCW, POP, 

dst^src 1 OR |1 1 1 0|dst/src | push.'rl RLC. RR. 



OR 1 1 1 dst 



OPC 


MODE 


dst 


src 



MODE 


OPC 


dst/src 


src/dst 



PUSH, RL. RLC, RR, 
RRC, SRA, SWAP 



JP, CALL (Indirect) 



ADC, ADD, AND, 
CP, OR, SBd, SUB, 
TCM, TM, XOR 



LD, LDE, LDEI, 
LDC, LDCI 



OPC I MODJ" 



OPC I MOPJ" 



MODE I OPC~ 



1110 


src 


1110 


dst 



ADC, ADD, AND, CP, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 



MODE 


OPC 


dst/src 


X 


ADDRESS 



ADC, ADD, AND, CP, 

OR |i 1 1 ol dst I '■°' °"' ^^^' S"^> 
OR n 1 T 0| qst I j^ j^Qp 



1110 


src 


1110 


dst 



dst/src I OPC 



dst I OPc" 



dst/CC I OPc" 



0| src I 



I OPC 



DAu 



DAl 



PAl 



TwO'Byte Instruction 



Three-Byte Instruction 



Figure 17. Instruction Formats 



INSTRUCTION SUMMARY 



instruction 
and Operation 




AddrlVIode 


Opcode 
Byte 
(Hex) 


Flags Affected 


dst src 


C Z S V D H 


ADC dst.src 

dst *- dst + src + 


C 


(Note1) 


in 


* * * * * 


ADD dst, src 
dst ^ dst -1- src 




(Note1) 


on 


* * * * * 


AND dst.src 
dst*- dst AND src 




(Motel) 


5n 


- * * 


CALL dst 

SP^SP - 2 
@SP - PC; PC - 


dst 


DA 
IRR 


D6 
D4 




CCF 

C-NOTC 






EF 


* 


CLRdst 

dst *- 




R 
IR 


BO 
B1 




COIVI dst 

dst -NOT dst 




R 
IR 


60 
61 


- * * 


CP dst, src 
dst - src 




(Note1) 


AD 


* * * * 


DA dst 

dst *- DA dst 




R . 
IR 


40 
' 41 


* * * X 



Instruction 


Addr iVIode 


Opcode 
Byte 


Flags Affected 








and Operation 


dst 


src 


(Hex) 


C Z S V D H 


DEC dst 


R 




00 


— * * * 


dst - dst - 1 


IR 




01 




DECW dst 


RR 




80 


— * * * 


dst - dst - 1 


IR 




81 




Dl 










IMR(7)-0 






8F 




DJNZ rdst 


RA 




rA 




r-r - 1 






r = 0- F 




ifr^O 










PC - PC + dst 










Range: +127,-128 










El 






9F 




IMR(7)-1 










INC dst 


r 




rE 


— * * * 


dst *- dst + 1 


R 
IR 




r = - F 
20 
21 




INCW dst 


RR 




AO 


— * * * 


dst - dst + 1 


IR 




A1 
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INSTRUCTION SUMMARY (Continued) 



Instruction 
and Operation 


Addr Mode 


Opcode 
Byte 
(Hex) 

BF 
*-1 


Flags Affected 


Addr Mode 


Opcode 
Byte 
(Hex) 

10 
11 


Flags Affected 


dst src 

SP + 1 
+ 2;II\/IR(7) 



* 


z 

4r 


s 

* 


V D H 
"k it it 


Instruction 

and Operation dst src 


C Z S V D H 


IRET 

FLAGS - @SP; SP - 
PC-@SP;SP-SP 


"LCdsti^.^^^^^H 


* * * * 








EO 
' El 






««- \^\^^z^l 


^ ^ ^ ^ — — 


JP ccdst 


DA 
IRR 




cD 

c = - F 

30 


" 


~ 


' 


"~ 




if cc is true 




CO 
CI 




PC - dst 


RRC dst i , , 1 R 


^ ^ ^ ^ — . — 


4£}H^ oH,P 




JR ccdst 
if cc is true, 
PC - PC 4- dst 


RA 

r 
r 
R 

r 

X 

r 

Ir . 

R 

R 

R 

IR 

IR 


Im 
R 
r 

X 
r 
Ir 
r 

R 
IR 
IM 
IM 
R 


cB 
c = 0- F 

rC 
r8 
r9 
r = 0- F 
C7 
D7 
E3 
F3 
E4 
E5 
E6 
E7 
F5, 


- 


^ 


^ 







SBCdst,src (Notel) 
dst *- dst ^ src *- C 


3n 


* * * * 1 * 


Range: +127,-128 
LD dst, src 


SCF 

C-1 


DF 


1 


dst *- src 




DO 

D1 




^RA rlqt 1 . 1 R ' 


-k it -k 




&MA Qol Ud HH "H 




SRP src Im 

RP *- src 


31 


. ■' 




SUBdst.src (Notel) 
dst ^ dst *- src 


2n 


* * * * 1 * 




SWAP dst ^I^p.^ R 
' 1 ' * ' IR 


FO 

F1 


X * * X 




TCMdst,src (Notel) 
(NOT dst) AND src 

TMdst,src (Notel) 
dst AND src 


en 


- * * 


LDCdst,src 
dst *- src 


r 
Irr 


Irr 
r 


C2 
D2 


— 


— 


— 


_ _ 


- * * - - 




Ir 

Irr, 


Irr 
Ir 


C3 
D3 


' 


" 








LDCI dst,src 

dst *- src 

r *- r + 1 ; rr *- rr + 1 


XORdst.src , (Notel) 
dst ^ dst XOR src ' 


BD 


- * * 




NOTE: These instructions have an identical set of ac 
which are encoded for brevity. The first opco 
the instruction set table above. The second r 
symbolically by a D in this table, and its valU' 
following table to the left of the applicable ad 
For example, the opcode of an ADC instructi 
addressing modes r (destination) and Ir (sou 




LDEdst.src 
dst -*- src 


r 
Irr 


Irr 
r 


82 
92 


— 


— 


— 


— ; 


Idressing modes, 
de nibble IS found in 
libble is expressed 


LDEI dst,src 

dst ^ src 

r^ r + 1; rr^rr + 1 


Ir 
Irr 


Irr 
Ir 


83 
93 


" 


" 


" 


__, 


e is found in the 
dressing mode pair 

on using the 
roe) is 1 3 


NOP 






FF 


- 


- 


- 


. 




OR dst,src 


(Notel) 


40 


- 


* 


* 





Addr Mode 




Lower 


dst *- dst OR src 


dst src 

r r 

r Ir 

R R ' ' 

R IR 

R IM 

IR IM 


Opcode Nibble 


POP dst 

dst^@SP; 
SP-SP + 1 


R 
IR 




50 

51 












PUSH src 

SP-SP - 1;@SP- 


-src 


R 
IR 


70 
71 


— 


— 


— 







RCF 

C-0 






CF 





— 


— 





RET 


+ 2 




AF 


— 


- 


— 





PC-@SP;SP<-SP 










•^IR 




90 
91 


* 


* 


* 


* 




RLc^st j^j^^__ 
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REGISTERS 



R240 SIO 
Serial I/O Register 

(FOh; Read/Write) 

I D7 1 De I D5 1 D4 I D3 1 D2 I Di I Dp I 



- SERIAL DATA (Dq = LSB) 



R244 TO 
Counter/Timer Register 

(F4h; Read/Write) 

|Dy[De|P5|D4|D3|D2|DiTDn 



To INITIAL VALUE (WHEN WRITTEN) 

-(RANGE: 1-256 DECIMAL 01-00 HEX) 

To CURRENT VALUE (WHEN READ) 



R241 TMR 
Time Mode Register 

(F1h; Read/Write) 



R245 PREO 
Prescaler Register 

(F5h; Write Only) 



b 



PelDj 



Tout MODES 
NOT USED = 00 

To OUT = 01 ' 

T, OUT = 10 
INTERNAL CLOCK OUT = 11 

T,N MOOES 

EXTERNAL CLOCK INPUT = 00 

GATE INPUT = 01 

TRIGGER INPUT = 10 

(NONRETRIGGERABLE) 

TRIGGER INPUT = 11 
(RETRIGGERABLE) 



D4 I Da I D^ I D, I dTJ 



U = 



D4|d3[d;|d, [do{ 



L 



COUNT MODE 

= To SINGLE-PASS 

1 = To MODULON 



-RESERVED (MUST BE 0) 



PRESCALER MODULO 
-(RANGE: 1-64 DECIMAL 
01-00 HEX) 



R242 T1 
Counter Timer 1 Register 

(F2h; Read/Write) 



R246 P2M 
Port 2 Mode Register 

.(F6h; Write Only) 



|D,|De|D,|D4|D3|D;|D,|Do| 



T, INITIAL VALUE (WHEN WRITTEN) 

-(RANGE 1-256 DECIMAL 01-00 HEX) 

T, CURRENT VALUE (WHEN READ) 



DJdJDs D4 D, Dj 



\EE\ 



?2n-P2r I/O DEFINITION 
- DEFINES BIT AS OUTPUT 
1 DEFINES BIT AS INPUT 



R243 PRE1 
Prescaler 1 Register 

' (F3h; Write Only) 



TlD^O, 



D4|D3|D2|Di|Do1 



COUNT MODE 
- 1 = T, MODULON 
= T, SINGLE-PASS 

CLOCK SOURCE 
_ 1 = T, INTERNAL 
= T, EXTERNAL 
TIMING INPUT 
(Tin) mode 

PRESCALER MODULO 
-(RANGE: 1-64 DECIMAL 



R247 P3M 
Port 3 Mode Register 

(F7h; Write Only) 



DalDzlOilDol 



Lo 



-RESERVED (MUST BE 



P33 = INPUT 
-° J } P33 = INPUT 

1 1 RESERVED 



P34 = OUTPUT 
P34 = Dfl/i 



_0 P3i = INPUT (T,n) P36 = OUTPUTJTpuT) 

1 P3i = DAV2/RDY2 P36 = RDY2/DAV2 

P3o = INPUT P37 = OUTPUT 

~ 1 P3o = SERIAL IN P37 = SERIAL OUT 

_0 PARITY OFF 

1 PARITY ON 



Figure 18. Control Registers 
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REGISTERS 

(Continued) 



R248P01M 
Port Register 

(F8h; Write Only) 



IPzIPbIDsId/ 



PO4-PO7 MODE 
OUTPUT = 00 
INPUT = 01 
A,j-Ai5 = IX 



T 



T 



PO0-PO3 MODE 

00 = OUTPUT 

01 = INPUT 
IX = A»-A,i 

STACK SELECTION 
- = EXTERNAL 
1 = INTERNAL 



- RESERVED (MUST BE 0) 



R252 FLAGS 
Flag Register 

(FCh; Read/Write) 

|d,|d6,|d5|d4|d3|d2|di|Do1 



Li; 



USER FLAG F1 

USER FLAG F2 
-HALF CARRY FLAG 
-DECIMAL ADJUST FL'AG 
-OVERFLOW FLAG 
-SIGN FLAG 
-ZERO FLAG 
-CARRY FLAG 



•ALWAYS EXTENDED TIMING AFTER RESET 



-' R249 IPR 
Interrupt Priority Register 

(F9h; Write Only) 



j D, I De I D5 I D4 I D3 I D; I D, I Dp"] 



IRQ3, IRQ5 PRIORITY (GROUP A) 

= IRQ5 > IRQ3 - 

1 = IRQ3 > IRQ5 

IROO, IR02 PRIORITY (GROUP B) 

= IRQ2 > IROO - 

1 = IROO > IRQ2 



IRQ1, IR04 PRIORITY (GROUP C) 

= IRQ1 > IRQ4 - 

1 = IRQ4 > IRQ1 



INTERRUPT GROUP PRIORITY 
RESERVED = 000 
C > A > B = 001 



R253 RP 
Register Pointer 

(FDh; Read/Write) 

JDrlDglDslDjDalDalD.lDol 



l:^ 



C > B > A = 101 
B > A > C = 110 
RESERVED =111 



T 



R250 IRQ 
Interrupt Request Register 

(FAh; Read/Write) 

I D, I De I D5 I D4 I D3 I D; I D, [ Dp I 
RESERVED (MUST BE 0) > L 



IRQ2 = P3i INPUT 
IR03 = P3o INPUT, SERIAL INPUT 
IRQ4 = To, SERIAL OUTPUT 
IROS = Ti 



R254 SPH 
Stack Pointer 

(FEh; Read/Write) 

|D7|Dg|D5|D4|D3|D;|D^|Do'| 



STACK POINTER UPPER 
" BYTE (SPe-SPis) 



R251 IMR 
Interrupt Mask Register 

(FBh; Read/Write) - 

I D, I De I D5 1 D« I D3 1 D; I D, I Dp I 



^ RESERVED (MUST BE 0) 
- 1 ENABLES l»|^TERRUPTS 



R255 SPL 
Stack Pointer 

(FFh; Read/Write) 

|d,|d6[d5[d4|d3|d;|d, [Dpi 



Figure 18. Control Registers (Continued) 
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Z8681/82 OPCODE MAP 



z 

I 8 



Lower Nibble (Hex) 
6 7 8 



6,5 


6,5 


6,5 


6,5 


10,5 


10,5 


10.5 


10,5 


6.5 


6.5 


12/10.5 


12/10,0 


6,5 


12/10,0 


6,5 




DEC 


DEC 


ADD 


ADD 


ADD 


ADD 


ADD 


ADD 


LD 


LD 


DJNZ 


JR 


LD 


JP 


INC 




Ri 


tRi 


ri.r2 


ri,lr2 


R2,Ri 


lR2,Ri 


Rl,IM 


IRl.lM 


ri,R2 


r2.Rl 


ri.RA 


ccRA 


ri,IM 


ccDA 


ri 




6,5 


6,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 
































RLC 


RLC 


ADC 


ADC 


ADC 


ADC 


ADC 


ADC 
































Ri 


iRi 


ri.r2 


I'1,lr2 


R2.R1 


iR2,Ri 


Rl.lM 


IRl,IM 
































6,5 


6,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 




INC 


INC 


SUB 


SUB 


SUB 


SUB 


SUB 


SUB 
































Ri 


IR1 


n.r2 


''i,lr2' 


R2.R1 


lR2,Ri 


Rl,IM 


IRl.lM 
































8,0 


6,1, 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 




dP 


SRP 


SBC 


SBC 


SBC 


SBC 


SBC 


SBC 
































IRRl 


IM 


ri,r2 


ri,lr2 


R2.R1 


IR2,Ri 


Rl,IM 


IRl,tM 
















' 
















8,5 


8,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 




DA 


DA 


OR 


OR 


OR 


OR 


OR 


OR 
































Ri 


iRi 


ri.r2 


M.lr2 


R2.R1 


lR2,Ri 


Rl,IM 


IRl,IM 
































10,5 


10,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 


POP 


POP 


AND 


AND 


AND 


AND 


AND 


AND 
































Ri 


iRi 


ri.r2 


ri,lr2 


R2.R1 


iR2,Ri 


Rl,IM 


IRl,IM 
































6,5 


6,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 




COM 


COM 


TCM 


TCM 


TCM 


TCM 


TCM 


TCM 
































Ri 


IRi 


ri,r2 


M,lr2 


R2.R1 


IR2.R1 


Rl,IM 


IRl.lM 
































10/12,1 


12/14,1 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 




PUSH 


PUSH 


TM 


TM 


TM 


TM 


TM 


TM 
































R2 


IR2 


ri,r2 


ri,lr2 


R2.R1 


IR2.R1 


Rl,IM 


IRl.lM 
































10,5 


10,5 


12,0 


18,0 










6,1 


DECW 


DECW 


LDE 


LDEI 






































Dl 


RRl 


IRi 


ri,lrr2 


Iri,lrr2 








































6,5 


6,5 


12,0 


18,0 










6,1 


RL 


RL 


LDE 


LDEI 






































El 


Ri 


IRi 


r2,lrri 


Ir2.t''n 








































10,5 


10,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 


14,0 


INCW 


INCW 


CP 


CP 


CP 


CP 


CP 


CP 






























RET 


RRl 


IRi 


ri,r2 


ri,lr2 


R2.R1 


lR2,Ri ■ 


Rl,IM 


IRl,IM 
































6,5 


6,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 


16,0 


CLR 


CLR 


XOR 


XOR 


XOR 


XOR 


XOR 


XOR 






























IRET 


Ri 


IRi 


n.r2 


ri,lr2 


R2.R1 


lR2,Ri 


Rl.lM 


IRl,IM 
































6,5 


6,5 


12,0 


18,0 








10,5 


6,5 


RRC 


RRC 


LDC 


LDCI 








LD 






























RCF 


Ri 


IRi 


ri,lrr2 


Iri,lrr2 








ri,x,R2 
































, 6,5 


6,5 


12,0 


18,0 


20,0 




20,0 


10,5 


6,5 


SRA 


SRA 


LDC 


LDCI 


CALL* 




CALL 


LD 






























SCF 


Ri 


IRi 


r2,lrri 


Ir2,lrri 


IRRl 




DA 


r2,x.Ri 
































6,5 


6,5 




6,5 


10,5 


10,5 


10,5 


10,5 


6,5 


RR 


RR 




LD 


LD 


LD 


LD 


LD 






























CCF 


Ri 


IRi 




ri,IR2 


R2.R1 


IR2.R1 


Rl,IM 


IRl,IM 
































8,5 


8,5 




6,5 




10,5 






6,0 


SWAP 


SWAP 




LD 




LD 


































NOP 


Ri 


IRi 




Iri,r2 




R2,IRi 






\ 


r 


^ 


r 


\ 


f 


1 


r 


^ 


r 


\ 


' 


1 


r 





LOWER 
OPCODE 
NIBBLE 



Bytes per instruction 



EXECUTION 
CYCLES 



V^ 



PIPELINE 
CYCLES 



OPCODE - 
NIBBLE 



CP 

R2.R1 



FIRST 
OPERAND 



A^ 



SECOND 
OPERAND 



Legend: 

R = 8-bit address 
r = 4-bit address 
Ri or ri = Dst address 
R2 or r2 = Src address 

Sequence: 

Opcode, First Operand, Second Operand 

NOTE: The blank areas are not defined. 



*2-byte instruction, fetch cycle appears as a 3-byte instruction 



65 



ABSOLUTE MAXIMUM RATINGS 

Voltages on all pins except RESET 

with respect to GND -0.3V to +7.0V 

Operating Ambient 

Temperature See Ordering Information 

Storage Temperature -65°Cto +150°C 



Stresses greater than those listed under Absolute Maximum Ratings may 
cause permanent damage to the device. This is a stress rating only; 
operation of the device at any condition above those indicated in the 
operational sections of these specifications is not implied. Exposure to 
absolute maximum rating conditions for extended periods may affect 
device reliability. 



STANDARD TEST CONDITIONS 



The DC characteristics listed below apply for the following 
standard test conditions, unless otherwise noted. All 
voltages are referenced to GND. Positive current flows into 
the referenced pin. 

Standard conditions are as folfows: 

■ + 4.75V <Vcc< + 5.25V 

■ GND = OV 

■ 0°C<Ta< +70°C for S (Standard temperature) 

■ - 40°C < Ta < + 100 °C for E (Extended temperature) 



FROM OUTPUT , 




150 pf ?fc 



Figure 19. Test Load 1 



DC CHARACTERISTICS 



Symbol 


Parameter 


Min 


Max 


Unit 


Condition 


VCH 


Clock Input High Voltage 


3.8 


Vcc 


V 


Driven by External Clock Generator 


VCL 


Clock Input Low Voltage 


-0.3 


0.8 


V 


Driven by External Clock Generator 


V|H 


Input High Voltage . 


2.0 


Vcc 


V 




V|L 


Input Low Voltage 


-0.3 


0.8 


V 




Vrh 


Reset Input High Voltage 


3.8 


Vcc 


V 


See Note 


Vrl 


Reset Input Low Voltage 


^0.3 


0.8 


V 




VOH 


Output High Voltage 


2.4 




V 


lOH = -250p(A 


Vol 


Output Low Voltage 




0.4 


V 


Iql = +2.0nnA 


l|L 


Input Leakage 


-10 


10 


mA 


OV < V|N < + 5.25V 


lOL 


Output Leakage 


-10 


10 


ixk 


OV < V|N < + 5.25V 


l|R 


Reset Input Current 




-50 


/.A 


Vcc = + 5,25V Vrl = OV 


Ice 


Vcc Supply Current 




150 


mA 


All outputs and I/O pins floating 



*The Reset line (pin 6) is used to place the Z8682 in external memory mode. This is accomplished as shown in Figure 1 3. 
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PORTO, 
DM 



DS 

(READ) 



DS 

(WRITE) 




Figure 20. External I/O or Memory Read/Write Timing 



AC CHARACTERISTICS 

External I/O or Memory Rea6 ar\6 Write Tinning 



Number Symbol 


Parameter 


Z8681/82 
8 MHz 

Min Max 


Z8681 
12 MHz 

Min Max 


Z8681 
16 MHz 

Min Max 


Notes 


1 


TdA(AS) 


Address Valid to AS tDelay 


50 




35 




20 




2,3 


2 


TdAS(A) 


AS T to Address Float Delay 


70 




45 




30 




2,3 


3 


TdAS(DR) 


AS t to Read Data Required Valid 




360 




220 




180 


1.2,3 


4 


TwAS 


AS Low Width 


80 




55 




35 




2,3 


5 


TdAz(DS) 


Address Float to DS i 



















6 


TwDSR 


DS (Read) Low Width 


250 




185 




135 




1,2,3 


7 


TwDSW 


DS (Write) Low Width 


160 




110 




80 




1,2,3 


8 


TdDSR(DR) 


DS >l to Read Data Required Valid 




200 




130 




75 


1,2,3 


9 


ThDR(DS) 


Read Data to DS t Hold Time 

















2,3 


10 


TdDS(A) 


DS t to Address Active Delay 


70 




45 








2,3 


11 


TdDS(AS) 


DSttoASiDelay 


70 




55 




30 




2,3 


12 


TdRA/V(AS) 


RA/V Valid to AS tDelay 


50 




30 




20 




2,3 


13 


TdDS(RA/V) 


DST to R/W Not Valid 


60 




35 




30 




2,3 


14 


TdDW(DSW) 


Write Data Valid to DS (Write) I Delay 


50 




35 




25 




2,3 


15 


TdDS(DW) 


DS t to Write Data Not Valid Delay 


60 




35 




30 




2,3 


16 


TdA{DR) 


Address Valid to Read Data Required Valid 




410 




255 




200 


1,2,3 


17 


TdAS{DS) 


AS t to DS i Delay 


80 




55 




40 




2,3 



NOTES: 

1 . When using extended memory timing add 2 TpC. 

2. Timing numbers given are for minimum TpC. 

3. See clock cycle time dependent characteristics table. 

4. 16 MHz timing is preliminary and subject to change. 



* All units in nanoseconds (ns). 

t Test Load 1 ' 

° All timing references use 2.0V for a logic "1" and 0.8V for a logic "0". 
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IRQn 
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Figure 21 . Additional Timing 



AC CHARACTERISTICS 

Additional Timing Table 



Number Symbol 


Parameter 


Z8681/82 
8 MHz 

Min Max 


Z8681 
12 MHz 

Min Max 


Z8681 
16 MHz 

Min Max 


Notes 


1 


TpC 


Input Clock Period 


125 


1000 


83 


1000 


62.5 


1000 


1 


2 


TrC.TfC 


Clock Input Rise and Fall Times 




25 




15 




10 


1 


3 


TwC 


Input Clock Width 


37 




70 




21 




1 


4 


TwTlnL 


Timer Input Low Width 


100 




70 




50 




2 


5 


TwTlnH 


Timer Input High Width 


3TpC 




3TpC 




3TpC 




2 


6 


TpTin 


Timer Input Period 


8TpC 




8TpC 




8TpC 




2 


7 


Trlin.TfTin 


Timer Input Rise and Fall Times 




100 




100 




100 


2 


8A 


TwIL 


Interrupt Request Input Low Time 


100 




70 




50 




2,4 


8B 


TwIL 


Interrupt Request Input Low Time 


3TpC 




3TpC 




3TpC 




2.5 


9 


TwIH 


Interrupt Request Input High Time 


3TpC 




3TpC 




3TpC 




2.3 



NOTES: 

1 . Clock tinning references use 3.8V for a logic "1" and 0.8V for a logic "0". 

2. Timing references use 2.0V for a logic "1" and 0.8V for a logic "0". 

3. Interrupt request via Port 3. 

4. Interrupt request via Port 3 (PS^-PSa) 

5. Interrupt request via Port 3 (PSq) 

6. 16 MHz timing Is preliminary and subject to change. 
* Units in nanoseconds (ns). 
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DAV 

(INPUT) 



RDY 

(OUTPUT) 



X 



DATA IN VALID 



(T^ 



\ 



-0- 
-0- 



\. 






-©- 



/■ 



Figure 22a. Input Handshake Timing 





DATA OUT 
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i 






DATA OUT VALID 




















U-^D^ 


X 4 
















DAV 

(OUTPUT) 




\ 




/ 










k ^ 












w 


'1 










RDY 

(INPUT) 




Figure 22b. Output Handshak 












6 Timing 








AC CHARACTERISTICS 






















Handshake Timing 
























Number Symbol 


Parameter 






Z8681/82 
8 MHz 

Min Max 


Z8681 
12 MHz 

Min Max 




Z8681 
16 MHz 

Min Max 


Notes 


1 


TsDI(DAV) 


Data In Setup Time 





















2 


ThDI(DAV) 


Data In Hold Time 




230 


160 






145 






3 


TwDAV 


Data Available Width 




175 


120 






110 






4 


TdDAVIf(RDY) 


DAV i Input tc 


RDY i Delay 






175 




120 






115 


1,2 


5 


TdDAVOf(RDY) 


DAV i Output 


to RDY i Delay 



















1,3 


6 


TdDAVIr(RDY) 


DAV t Input tc 


RDY T Delay 






175 




120 






115 


1.2 


7 


TdDAVOr(RDY) 


DAV T Output 


to RDY t Delay 



















1.3 


8 


TdDO(DAV) 


Data Out to DAV i Delay 




50 


30 






30 




1 


9 


TdRDY(DAV) 


Rdy i Input to 


DAV T Delay 




200 





140 







130 


1 



NOTES: 

1 . Test load 1 

2 Input handshake 

3. Output handshake 

4. 16 MHz timing is preliminary and subject to change. 

t All timing references use 2.0V for a logic "1" and 0.8V for a logic "0". 
* Units in nanoseconds (ns). 
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CLOCK CYCLE TIME-DEPENDENT 
CHARACTERISTICS 







Z8681/82 


28681/82 






8 MHz 


12 MHz 


Number 


Symbol 


Equation 


Equation 


1 


TdA(AS) 


TpC-75 


' TpC-50 


2 


TdAS(A) 


TpC-55 


.TpC-40 


3 


TdAS(DR) 


4TpC-140* 


4TpC-110* 


4 


TwAS 


TpC-45 


TpC-30 


6 


TwDSR 


3TpC-125* 


3TpC-65* 


7 


TwDSW 


2TpC-90* 


2TpC-55* 


8 


TdDSR(DR) 


3TpC-175* 


3TpC-120* 


10 


Td(DS)A 


TpC-55 ' 


TpC-40 


11 


TdDS(AS) 


TpC-55 


TpC-30 


12 


TdR/W(AS) 


TpC-75 


TpC-55 


13 


TdDS(R/W) 


TpC-65 


TpC-50 


14 


TdDW(DSW) 


TpC-75 


TpC-50 


15 


TdDS(DW) 


TpC-55 


TpC-40 


16 


TdA(DR) 


5TpC-215* 


5TpC-160* 


17 


TdAS(DS) 


TpC-45 


TpC-30 



* Add 2TpC when using extended memory timing 
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Product Specification 



June 1987 



Z8691Z8® 

ROMless Microcomputer 



FEATURES 

■ Complete microcomputer, 24 I/O lines, and up to 64K 
bytes of addressable external space each for program 
and data memory. 

■ 143-byte register file, Including 124 general-purpose 
registers, 3 I/O port registers, and 16 status and control 
registers. 

■ Vectored, priority interrupts for I/O, counter/timers, and 
UART. 

■ On-chip oscillator that accepts crystal or external clock 
drive. 



Full-duplex UART and two programmable 8-bit 
counter/timers,, each with a 6-bit programmable 
prescaler. 

Register Pointer so that short, fast instructions cap 
access any one of the nine working-register groups. 

Single + 5V power supply— all I/O pins TTL compatible. 

8 MHz/12 MHz versions. 



GENERAL DESCRIPTION 



The Z8691 is a ROMless version of the Z8 single-chip 
microcomputer. The Z8691 offers all the outstanding 
features of the Z8 family architecture except an on-chip 
program ROM. Use of external memory rather than a 



preprogrammed ROM enables this Z8 microcomputer to be 
used in low volume applications or where code flexibility is 
required. 
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AND CONTROL 
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39 
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37 
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5 


36 
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35 
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7 
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8 


33 
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32 
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10 Z8691 31 
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29 
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13 


28 
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15 
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24 
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18 
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19 
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20 


21 
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Figure 1 . Pin Functions 



Figure 2a. 40-pin Dual-ln-Line Pacloge (DIP), 
Pin Assignments 
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The Z8691 can provide up to 16 output address lines, tiius 
permitting an address space of up to 64K bytes of data or 
progrann memory. Eight address outputs (AD0-AD7) are 
provided by a multiplexed, 8-bit, Address/Data bus. The 
remaining 8 bits can be provided by the software 
configuration of Port to output address bits As-A-is. 

Available address space can be doubled (up to 128K bytes) 
by programmin£bit 4 of Port 3 (P34) t o act as a data memory 
select output (DM). The two states of DM together with the 
16 address outputs can define separate data and memory 
address spaces of up to 64K bytes each . 



There are 143 bytes of RAM located on-chip and organized 
as a register file of 124 general-purpose registers, 16 control 
and status registers, and three I/O port registers. This 
register file can be divided into nine groups of 16 working 
registers each. Configuring the register file in this manner 
allows the use of short format instructions; in addition, any of 
the individual registers can be accessed directly 

The pin functions and the pin assignments of the Z8691 
40-pin and 44-pin packages are illustrated in Figures 1 and 2, 
respectively 



^O <j'b'*^'V\^^^^^^ ^'b%'b*'^'V\'V«'<j'V^ 
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12 




Z8691 
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35 
34 


P32 


13 






33 


POo 


14 






32 


PO1 


15 






31 


PO2 


16 






,30 


NC 


17 






29 
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Figure 2b. 44-pin Chip Carrier, 
Pin Assignments 



OUTPUT INPUT 



Vcc GND 



XTAL AS DS R/W RESET 




(BIT PROGRAMMABLE) 



ADDRESS OR I/O 
(NIBBLE PROGRAMMABLE) 



ADDRESS/DATA 



ZBUS WHEN USED AS 
ADDRESS/DATA BUS 



Figure 3. Functionai Blocic Diagram 
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ARCHITECTURE 



Z8691 architecture is characterized by a flexible I/O 
scheme, an efficient register and address space structure 
and a nunnber of ancillary features that are helpful in nnany 
applications. 

Microconnputer applications demand powerful I/O 
capabilities. The Z8691 fulfills this with 24 pins available for 
input and output. These lines are grouped into three ports of 
eight lines each and are configurable under software control 
to provide timing, status signals, serial or parallel I/O with or 
without handshake, and an Address bus for interfacing 
external memory 

Three basic address spaces are available: program memory 



data memory and the register file (internal). The 143-byte 
random-access register file is composed of 124 
general-purpose registers, three I/O port registers, and 16 
control and status registers. 

To unburden the program from coping with real-time 
problems such as serial data communication and 
counting/timing, an asynchronous receiver/transmitter 
(UART) and two counter/timers with a large number of 
user-selectable modes are offered on-chip. Hardware 
support for the UART is minimized because one of the 
on-chip timers supplies the bit rate. Figure 3 shows the 
Z8691 block diagram. 



PIN DESCRIPTION 



AS. Address Strobe (output, active Low). Address Strobe is 
pulsed once at the beginning of each machine cycle. 
Addresses output via Port 1 for all external program or data 
memory transfers are valid at the trailing edge of AS. 

DS. Data Strobe (output, active Low). Data Strobe is 
activated once for each external memory transfer. 

POo-POj, P2o-P27, P3o-P37. I/O Port Lines (input/outputs, 
TTL-compatible). These 24 lines are divided into three 8-bit 
I/O ports that can be configured under program control for 
I/O or external memory interface (Figure 3). 

Plo-Ply. Address/ Data Port (bidirectional). Multiplexed 



address (A0-A7) and data (D0-D7) lines used to interface with 
program and data memory 



RESET. Reset (input, active Low). RESET initializes the 
Z8691. After RESET the Z8691 is in the extended memory 
mode. When RESET is deactivated, program execution 
begins frpm program location OOOCh- 

R/W. f?eaGf/l/\/r/te (output). R/W is Low when the Z8691 
is writing to external program or data memory. 

XTAL1, XTAL2. Crystal 1, Crystal 2 (time-base input and 
output). These pins connect a parallel- resonant crystal to the 
on-chip clock oscillator and buffer. 
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ADDRESS SPACES 



Program Memory. The Z8691 addresses 64K/62K bytes of 
external program memory space (Figure 4). 

The first 12 bytes of program memory are reserved for the 
interrupt vectors. These locations contain six 16-bit vectors 
that correspond to the six available interrupts. Program 
execution begins at location OOOCh after a reset. 

Data Memory. The Z8691 can address 64K bytes of external 
data memory. External data memory may be included wi th or 
separated from the external prbgram memory space. DM, 
an optional I/O function that can be programmed to appear 
on pin P34, is used to distinguish between data and program 
memory space. 

Register File. The 143-byte register file includes three I/O 
port registers (RO, R2, R3), 124 general-purpose registers 
(R4-R127) and 16 control and status registers (R240-R255). 
These registers are assigned the address locations shown in 
Figure 5. 



Z8691 instructions can access registers directly or indirectly 
with an 8-bit address field. This also allows short 4-bit 
register addressing using the Register Pointer (one of the 
control registers). In the 4-bit mode, the register file is divided 
into nine working-register groups, each occupying 16 
contiguous locations (Figure 5). The Register Pointer 
addresses the starting location of the active working- register 
group (Figure 6). 

Stacks. Either the internal register file or the external data 
memory can be used for the stack. A 16-bit Stack Pointer 
(R254 and R255) is used for the external stack, which can 
reside anywhere in data memory. An 8-bit Stack Pointer 
(R255) is used for the internal stack that resides within the 
124 general-purpose registers (R4-R127). 



LOCATION OF FIRST 
BYTE OF INSTRUCTION 
EXECUTED AFTER " 
RESET 



INTERRUPT 

VECTOR . 

(LOWER BYTE) 

INTERRUPT 
VECTOR' 
(UPPER BYTE) 



PROGRAM 
MEMORY 


DATA 
MEMORY 


— IRQ5 


IRQ4 


— IRQ3 


— IRQ2 


— IRQ1 


— IRQO 



Figure 4. Program IVIemory Map 
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DEC 




HEX 

FF 

FE 

FD 

FC 

FB 

FA 

F9 

F8 

F7 

F6 

F5 

F4 

F3 

F2 

F1 

FO 

7F 

04 
03 
02 
01 
00 


IDENTIFIERS 


255 


STACK POINTER (BITS 7-0) 


SPL 


254 


STACK POINTER (BITS 15-8) 


SPH 


253 


REGISTER POINTER 


RP 


252 


PROGRAM CONTROL FLAGS 


FLAGS 


251 


INTERRUPT MASK REGISTER 


IMR 


250 


INTERRUPT REQUEST REGISTER 


IRQ 


249 


INTERRUPT PRIORITY REGISTER 


IPR 


248 


PORTS 0-1 MODE 


P01M 


247 


PORT 3 MODE 


P3M 


246 


PORT 2 MODE 


P2M 


245 


TO PRESCALER 


PREO 


244 


TIMER/COUNTER 


TO 


243 


T1 PRESCALER 


PRE1 


242 


TIMER/COUNTER 1 


T1 


241 


TIMER MODE 


TMR 


240 


SERIAL I/O 


SIO 




NOT 
IMPLEMENTED 




127 
4 


GENERAL-PURPOSE 
REGISTERS 




3 


PORT 3 


P3 


2 


PORT 2 


P2 


1 


P0RT1 


PI 





PORT 


PO 



1 - 


255 


h h h u 1 





253 
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THE UPPER NIBBLE OF THE REGISTER 
FILE ADDRESS PROVIDED BY THE 
REGISTER POINTER SPECIFIES THE 
ACTIVE WORKING-REGISTER GROUP. 



SPECIFIED WORKING- 
REGISTER GROUP 



THE LOWER 
NIBBLE OF 
THE REGISTER 
FILE ADDRESS ■ 
- PROVIDED BY 
THE INSTRUCTION 
POINTS TO THE 
SPECIFIED 
REGISTER. 



Figure 5. The Register File 



Figure 6. The Register Pointer 



SERIAL INPUT/OUTPUT 



Port 3 lines P3o and PSy can be programmecj as serial I/O 
lines for fulWuplex serial asynchronous receiver /transmitter 
operation. The bit rate is controlled by Counter/Tinner 0, with 
a maximunn rate of 62.5K bits/second at 8 MHz or 93.75K 
bits /second at 12 MHz on the Z8691. 

The Z8691 autonnatically adds a start bit and two stop bits to 
transmitted data (Figure 7). Odd parity is also available as an 
option. Eight data bits are always transmitted, regardless of 



parity selection. If parity is enabled, the eighth data bit is 
used as the odd parity bit. An interrupt request (IRQ4) is 
generated on all transmitted characters. 

Received data must have a start bit, eight data bits, and at 
least one stop bit. If parity is on, bit 7 of the received data is 
replaced by a parity error flag. Received characters 
generate the IRQ3 interrupt request. 



|SP 


sp|d7|d6|d5|d4 


D3|d2|di|do|st| 










* 


L 









START telT 
EIGHT DATA BITS 
TWO STOP BITS 




START BIT 
EIGHT DATA BITS 
ONE STOP BIT 



Transmitted Data 
(No Parity) 



Received Data 
(No Parity) 



sp| p |D6|D5|D4|D3|D2|d^|Do|st 

L 



START BIT 
SEVEN DATA BITS 
ODD PARITY 
TWO STOP BITS 



SP P Dg Dc D4 Do Do DJ Do ST 



L 



START BIT 
SEVEN DATA BITS 
PARITY ERROR FLAG 
ONE STOP BIT 



Transmitted Data 
(With Parity) 



Figure 7. Serial Data Formats 



Received Data 
(With Parity) 
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COUNTER/TIMERS 



The Z8691 contains two 8-bit programmable counter/timers 
(To and Ti), each driven by its own 6-bit programmable 
prescaler. The Ti prescaler can be driven by internal or 
external clock sources; however, the To prescaler is driven 
by the internal clock only. 

The 6-bit prescalers can divide the input frequency of the 
clock source by any number from 1 to 64. Each prescaler 
drives its counter, which decrements the value (1 to 256) that 
has been loaded into the counter. When the counter reaches 
the end of count, a timer interrupt request — IRQ4 (Tq) or 
IRQ5 (Ti)— is generated. 

The counters can be started, stopped, restarted to continue, 
or restarted from the initial value. The counters can also be 
programmed to stop upon reaching zero (single-pass mode) 



or to automatically reload the initial value and continue 
counting (modulo-n continuous mode). The counters, but not 
the prescalers, can be read any time without disturbing their 
value or count mode. 

The clock source for Ti is user-definable; it can be either the 
internal microprocessor clock divided by four, oi' an external 
signal input via Port 3. The Timer Mode register configures 
the external timer input as an external clock, a trigger input 
that can be retriggerable or nonretriggerable, or as a gate 
input for the internal clock. The counter /timers can be 
programmably cascaded by connecting the Tq output to the 
input of Ti . Port 3 line P36 also serves as a timer output (Tqut) 
through which Tq, Ti or the internal clock can be output. 



I/O PORTS 



The Z8691 has 24 lines available for input and output. These 
lines are grouped into three ports of eight lines each and are 
configurable as input, output or address. Under software 
control, the ports can be programmed to provide address 



outputs, timing, status signals, serial I/O, and parallel I/O 
with or without handshake. All ports have active pull-ups and 
pull-downs compatible with TTL loads. 



Port 1 is a dedicated Z-BUS compatible memory interface. 
The operations of Port 1 are supported by the Address Strobe 
(AS) and Data Strobe (PS) lines, and by the Read/Write 
(R/W) and Data Memory (DM) control lines. The low-order 
program and data memory addresses (A0-A7) are output 
through Port 1 (Figure 8) and are multiplexed with data in /out 
(D0-D7). Instruction fetch and data memory read /write 
operations are done through this port. 

Port 1 cannot be used as a register nor can a handshake 
mode be used with this port. 

The Z8691 wakes up with the 8 bits of Port 1 configured as 
address oXitputs for external memory. If more than eight 
address lines are required, additional lines can be obtained 
by programming Port bits as address bits. The 



least-significant four bits of Port can be configured to 
supply address bits As-An for 4K byte addressing or both 
nibbles of Port can be configured to supply address bits 
A8-A15 for 64K byte addressing. 



(^ 



Z8691 
MCU 



PORT 1 

AD0-AD7 

TO EXTERNAL 
MEMORY 



Figure 8. Port 1 



Port pan be programmed as a nibble I/O port, or as an 
address port for interfacing external memory (Figure 9). 
When used as an I/O port. Port can be placed under 
handshake control. In this configuration. Port 3 lines P32 and 
P35 are used as the handshake controls DAVo and RDYo. 
Handshake signal assignment is dictated by the I/O 
direction of the upper nibble PO4-PO7. 

For external memory references. Port can provide address 
bits As-All (lower nibble) or A8-A15 (lower and upper nibbles) 
depending on the required address space. If the address 
range requires 12 bits or less, the upper nibble of Port can 
be programmed independently as I/O while the lower nibble 
is used for addressing. 

Port lines are configured as address lines Aq-A^^ after a 
reset. If one or both nibbles are needed for I/O operation, 
they must be configured by writing to the Port Mode 
register. 



To permit the use of slow memory, an automatic wait mode of 
two oscillator clock cycles is configured for the bus timing of 
the Z8691 after each reset. The initialization routine could 
include reconfiguration to eliminate this extended timing 
mode. 



Z8691 
MCU 




PO4-PO7 I PORT 
PO0-PO3 f(l/OORA8-Ai5 



. HAND SHAKE CONTROLS 
} DAVo AND RDYo 
' (P32 AND P35) 



Figure 9. Port 
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Port 2 bits can be programmed independently as input or 
output (Figure 10). Tliis port is always available for I/O 
operations. In addition, Port 2 can be configured to provide 
open-drain outputs. 

Port 2 may also be placed under handshake control. In this 
configuration, Port 3 lin es P 3i and PSe are used as the 
handshake controls lines DAV2 and RDY2. The handshake 
signal assignment for Port 3 lines P3-^and P36 is dictated by 
the direction (input or output) assigned to bit 7 of Port 2. 



Z8691 
MCU 



PORT 2(1/0) 



P27 

HANDSHAKE CONTROLS 
DAV2 AND RDY2 



(P3i AND PSg) 

Figure 10. Port 2 



Port 3 lines can be configured as I /O or control lines (Figure 
11). In either case, the direction of the eight lines is fixed as 
four input (PSq-PSs) and four output (P34-P37). For serial I/O, 
lines P3o and P37 are programmed as serial in and serial out, 
respectively 

Port 3 can also provide th e fo llowing control functions: 
handshake for Ports and 2 (DAV and RDY); four external 
interrupt request signals (IRQ0-IRQ3); timer input and output 
signals (T|n and Tqut) and Data Memory Select (DM). 



Z8691 
MCU 



PORTS 

(I/O OR CONTROL) 



Figure 11. Port 3 



INTERRUPTS 



The Z8691 allows six different interrupts from eight sources: 
the four Port 3 lines P3o-P33, Serial In, Serial Out, and the two 
counter/timers. These interrupts are both maskable and 
prioritized. The Interrupt Mask register globally or 
individually enables or disables the six interrupt requests. 
When more than one interrupt is pending, priorities are 
resolved by a programmable priority encoder that is 
controlled by the Interrupt Priority register. 

All interrupts are vectored through locations in program 
memory. When an interrupt request is granted,, an Interrupt 
machine cycle is entered. This disables all subsequent 



interrupts, saves the Program Counter and status flags, and 
accesses the program memory vector location reserved for 
that interrupt. This memory location and the next byte 
contain the 16-bit address of the interrupt service routine for 
that particular interrupt request. The Z8691 takes 63 
crystal cycles to enter an interrupt subroutine. 

Polled interrupt systems are also supported. To 
accommodate a polled structure, any or all of the interrupt 
inputs can be masked and the Interrupt Request register 
polled to determine which of the interrupt requests needs 
service. 



CLOCK 



The on-chip oscillator has a high-gain, parallel-resonant 
amplifier for connection to a crystal or to any suitable 
external clock source (XTAL1 = Input, XTAL2 = Output). 

The crystal source is connected across XTAL1 and XTAL2, 
using the recommended capacitance (Cl = 15 pf 
maximum) from each pin to ground. The specifications for 
the crystal are as follows: 



AT cut, parallel-resonant 
Fundamental type 
Series resistance, Rg < 100 Q 
8 or 12 MHz maximum 
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INSTRUCTION SET NOTATION 



Addressing Modes. The following notation is ,used to 
describe the addressing modes and Instruction operations 
as shown In the instruction sumnnary. 

IRR Indirect register pair or Indirect working-register 

pair address 

Irr Indirect working-register pair only 

X Indexed address 

DA Direct address 

RA Relative address 

IM Immediate 

R Register or working-register address 

r Working-register address only 

IR Indirect-register or indirect working-register 

address 

Ir ' Indirect working-register address only 

RR Register pair or working register pair address 

Symbols. The following symbols are used in describing the 
instruction set. 

dst Destination location or contents 

src Source location or contents 

CO Condition code (see list) 

@ Indirect address prefix 

SP Stack pointer (control registers 254-255) 

PC Program counter 

FLAGS Flag register (control register 252) 

RP Register pointer (control register 253) 

IMR Interrupt mask register (control register 251 ) 



Assignment of a value Is indicated by the symbol "^". For 
example, 

dst ^ dst -f src 

indicates that the source data Is added to the destination 
data and the result is stored In the destination location. The 
notation "addr(n)" is used to refer to bit "n" of a given 
location. For example, 

dst (7) 

refers to bit 7 of the destination operand. 

Flags. Control Register R252 contains the following six 
flags: 

C 

z 
s 

V 
D 
H 



Carry flag 
Zero flag 
Sign flag 
Overflow flag 
Decimal-adjust flag 
Half-carry flag 

Affected flags are indicated by: 

Cleared to zero 

1 Set to one 

* Set or cleared according to operation 

— Unaffected 

X Undefined 



CONDITION CODES 


Value Mnemonic 




Meaning 


Flags Set 


1000 




Always true 




~ . 


0111 





Garry 




= 1 


1111 


NO 


No carry 




= 


0110 


z 


Zero 




Z = 1 


1110 


NZ 


Not zero 




Z = 


1101 


PL 


Plus 




8 = 


0101 


Ml 


Minus 




8 = 1 


0100 


ov 


Overflow 




V = 1 


1100 


NOV 


No overflow 




V = 


0110 


EG 


Equal 




Z = 1 


1110 


NE 


Not equal 




Z = 


1001 


GE 


Greater than 


or equal 


(SXORV) = 


0001 


LT 


Less than 




(8X0RV) = 1 


1010 


GT 


Greater than 




[ZOR(8XORV)] = 0. 


0010 


LE 


Less than or > 


equal 


[Z0R(8X0RV)] = 1 


1111 


UGE 


Unsigned greater than or equal 


= 


0111 


ULT 


Unsigned less than 


0= 1 


1011 


UGT 


Unsigned greater than 


(O = 0ANDZ = 0) = 1 


0011 


ULE 


Unsigned less than or equal 


(00RZ) = 1 


0000 




Never true 




— 
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INSTRUCTION FORMATS 



CCF, Dl. El, IRET, NOP, 
RCF, RET, SCF 



I dst 



One-Byte Instruction 



OPC I MODE 



OR 1 1 1 dst/src 



OR I1 1 1 dst 



OPC 


MODE 


dst 


src 



MODE 


OPC 


dst/src 


src/dst 



CLR, CPL, DA, DEC, 
DECW, INC, INCW, POP, 
PUSH, RL, RLC, RR, 
RRC, SRA, SWAP 

JP, CALL (Indirect) 



ADC, ADD, AND, 
CP, OR, SBC, SUB, 
TCM, TM, XOR 



LD, LDE, LDEI, 
LDC, LDCI 



OPC I MODJ" 



OPC I MODE 



MODE I OPc" 



1110 


src 


1110 


dst 



ADC, ADD, AND, CP, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 



ADC, ADD, AND, CP, 

OR h 1 1 ol dst I '-°' °^' S^<^' S"^' 
OR P T T 0| qst I j^ j^Qp 



1110 


src 


1110 


dst 



MODE 


OPC 


dst/src 


X 


ADDRESS 



dst/src OPC 



dst/CC OPC 



OR |l 1 1 0| src 



I OPC 



DAl 



DAu 



Two-Byte instruction 



Tliree— Byte instruction 



Figure 12. Instruction Formats 



INSTRUCTION SUMMARY 



Instruction 
and Operation 




Addr Mode 


Opcode 
Byte 
(Hex) 


Flags Affected 


dst src 


C Z S V D H 


ADC dst.src 

dst ^ dst + src + 


C 


(Note1) 


in 


* * * * * 


ADD dst.src 
dst *- dst + src 




(Note1) 


on 


* * * * * 


ANDdst,src 
dst*- dst AND src 




(Note 1) 


5n 


- * * 


CALL dst 

SP-SP - 2 
@SP - PC; PC - 


dst 


DA 
IRR 


D6 
D4 




CCF 

C ^ NOT C 






EF 


* 


CLR dst 

dst - ^ 




R 
IR 


BO 
B1 




COM dst 

dst ^ NOT dst 




R 
IR 


60 
61 


- * * 


CP dst, src 
dst - src 




(Note1) 


AD 


* * * * 


DA dst 

dst *- DA dst 




R 
IR 


40 
41 


* * * X 





Addr 


Mode 


Opcode 
Byte 
(Hex) 


Flags Affected 


instruction 
and Operation 


dst 


src 


C Z S V D H 


DEC dst 

dst ^ dst - 1 


R 
IR 




00 
01 


— * * • 


DECW dst 

dst *- dst - 1 


RR 
IB 




80 
81 


— * * * 


Dl 

IMR(7)-0 






8F 





DJNZ rdst 
r -^ r - 1 
ifr^O 

PC - PC + dst 
Range: +127, -128 



RA 



El 

IMR(7)- 



INCW dst 

dst *- dst + 1 



RR 
IR 



rA 
: - 



9F 



INC dst 


r 


rE 


dst *- dst + 1 




r = - F 




R 


20 




IR 


21 



AO 
A1 
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INSTRUCTION SUMMARY (Continued) 



AddrMode 


Opcode Flags Affected 

Byte 

(Hex) C Z S V D H 


Instruction 

^ndOperation dst src 


fRET 

FLAG'S ^@SP;SP^SP + 1 
PC -- @SP; SP ^ SP + 2; IMR (7) 


BF ****** 

*-1 


JPccdst DA 
if cc is true 
PC ^ dst IRR 


cD 

c = 0'- F 
30 



JRccdst 




RA 




if cc is true, 








PC -- PC + 


dst 






Range: +127, 


-128 






LD dst.src 




r 


Im 


dst *- src 




r 


R 






R 

r 


r 
X 






X 


r 






r 


Ir 






Ir 


r 






R- 


.R 






R 


IR 






R 


IM 






iR 


IM 






IR 


R 



cB 

- - F 

rC 
r8 
r9 
= - F 
C7 
07 

E3 . 
F3 
E4 
E5 
E6 
E7 
F5 



kOC dst.src 
dst ** src 


r 
Irr 


Irr 
r 


C2 
02 


__ -_ 


_ . 


. too dst.src 
dst *- src 
r *-r + 1; rr*-rr + 1 


Ir 
Irr 


Irr 
Ir 


C3 
03 


"" 




iOe dst.src 
dst *- src 


r 
Irr 


Irr 

r 


82 
92 








im\ dst.src 

dk *- src 

r*-r + 1; rr*-rr + 1 


Ir 
Irr 


Irr 

Ir 


83 
93 


"" 




NOP 






FF , 








/ 


OR dst.src 

dst *- dst OR src 


(Note 


'1) 


4n 


— * 


* - - 


POP dst 

dst *- @SP; 
SP *- SP -f 1 


R 
IR 




50 

51 










PUSH src 

SP--SP - 1;@SP^ 


src 


R 
IR 


70 
71 










RCF 

C^O , 






CF 


- 





mr 

PC*^@SP;SP-SP - 


f 2 




AF 










IR 




90 
91 


* * 




'^"^^ mM^^ 


* * 





AddrMode 


Opcode 
Byte 
(Hex) 


Flags Affected 


Instruction 
and Operation 


dst src 


C Z S V D H 






10 

11 




HL^C.3t^^^^^_jJH 


* * * * 






EO 
El 




««^^^ imlEz^^i;^ 


* * * * 






CO 
CI 




R«cdst^^j_^ 


-^rR 


* * * * 


SBC dst.src (Note1) 
dst ^ dst *- src ^ C 


' 3Q 


* * * * 1 * 


SCF 

C-1 




DF 


1 


SRAdstL0^y-^R 


DO 
01 


* * * 


SRP src 

RP *- src 


Im 


31 




SUB dst.src 
dst *- dst '*- src 


(Notel) 


2n 


* * * * 1 * 


SWAP dst , r~r 


7^ IR 


FO 
F1 


X * * X 


TOM dst.src 
(NOT dst) AND src 


(Notel) 


en 


- * * 


TM dst.src 
dst AND src 


(Notel) 


7n 


- * * 


XOR dst.src 

dst ^ dst XOR src 


(Notel) 


BD 


- * * 



NOTE: These instructions have an identical set of addressing modes, 

which are encoded for brevity. The first opcode nibble is found in 
the instruction set table above. The second nibble is expressed 
synnbolically by a TI in this table, and its value is found in the 
following table to the left of the applicable addressing mode pair 
For example, the opcode of an ADC instruction using the 
addressing modes r (destination) and Ir (source) is 13. 



Addr Mode 



dst 



Lower 
Opcode Nibble 



r 


Ir 


R 


R 


R 


IR 


R 


IM 


IR 


IM 



m 
m 
m 
m 

m 
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REGISTERS 



R240 SIO 
Serial I/O Register 

(FOh; Read/Write) 

|D;|d,|d5|d4|d3|d2|d,|do| 



R244 TO 
Counter/Timer Register 

(F4h; Read/Write) 

|D;|Dg|D5|D4|D3|D^[D,|Do| 



- SERIAL DATA (Dg = LSB) 



To CURRENT VALUE (WHEN READ) 



R241 TMR 
Time Mode Register 

(F1h; Read/Write) 



R245 PREO 
Prescaler Register 

(F5h; Write Only) 



Tout MODES 

NOT USED = 00 

To OUT = 01 

T, OUT = 10 

INTERNAL CLOCK OUT » 11 

T,M MOOES 

EXTERNAL CLOCK INPUT = 00 

GATE INPUT = 01 

TRIGGER INPUT = 10 

(NON-RETRIGQERABLE) 

TRIGGER INPUT = 11 
(RETRIGGERABLE) 



K 


DslDs 


D,JD,JDjJD, JDol 








L 



= NO FUNCTION 
"1 = LOADT, 



P^!P»|P'|PilP'i 



COUNT MODE 
- = To SINGLE-PASS 
1 = To MODULO-N 



-RESERVED (MUST BE 0) 



R242 T1 
Counter Timer 1 Register 

(F2h; Read/Write) 

' JD.lDolD.lDjDalD^lDjDn 



R246 P2M 
Port 2 Mode Register 

(F6h; Write Only) 

' iD7[P6|D5|D4[D3|D2|Dl|Do| 



Tt CURRENT VALUE (WHEN READ) 



P2o-P27 I/O DEFINITION 
- DEFINES BIT AS OUTPUT 
1 DEFINES BIT AS INPUT 



R243 PRE1 
Prescaler 1 Register 

(F3h; Write Only) 



TdHd 



D4 Dj D, DJDo 



COUNT MODE 
- 1 = T, MODULON 
= T, SINGLE-PASS 

CLOCK SOURCE 
_ 1 = T, INTERNAL 
= T, EXTERNAL 
TIMING INPUT 
(T,n) MODE 

PRESCALER MODULO 
-(RANGE: 1-64 DECIMAL 
01-00 HEX) 



R247 P3M 
Port 3 Mode Register 

(F7h; Write Only) 



JD,|D6|Ds|D, 



Lo 



-RESERVED (MUST BE 0) 



P33 = INPUT 
-°J} P33 = INPUT 

1 1 RESERVED 



P34 = OUTPUT 
P34 = BSi 



P3i = INPUT (T,,^) P36 = OUTPUTJToUt) 

1 P3i = DAV2/ROY2 PSe = ROY2/BS92 



Figure 13. Control Registers 
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REGISTERS 

(Continued) 



R248P01M 
Port Mode Register 

(F8h; Write Only) 



R252 FLAGS 
Flag Register 

(FCh; Read/Write) 



EXTERNAL 
MEMORY TIMING - 
NORMAL = 
•EXTENDED = 1 



|D;|D6|D5|D4 


D3|d,|d,|do| 



D, De Os D4 D3 Oj 



PO0-PO3 MODE 

00 = OUTPUT 

01 = INPUT 
1X = Ag-A,, 

STACK SELECTION 
■• EXTERNAL 
: INTERNAL 



RESERVED (MUST BE 0) 



\EE1 



USER FLAG F1 

USER FLAG F2 
-HALF CARRY FLAG 
-DECIMAL ADJUST FLAG 
-OVERFLOW FLAG 
-SIGN FLAG 
-ZERO FLAG 



•ALWAYS EXTENDED TIMING AFTER RESET 



R249 iPR 
Interrupt Priority Register 

(F9h; Write Only) 



R253 RP 
Register Pointer 

(FDh; Read/Write) 



IRQ3, IRQ5 PRIORITY (GROUP A) 

= IRQ5 > IRQ3 - 

1 = IRQ3 > IRQ5 

IROO, IR02 PRIORITY (GROUP B) 

= IRQ2 > IRQO 

1 = IRQO > IRQ2 

IRQ1, IRQ4 PRIORITY (GROUP C) 

= IRQ1 > IRQ4 

1 = IRQ4 > IRQ1 



I D, [ De I D5 I D, [ D3 I D; I D, I D( 

ZI T" 



INTERRUPT GROUP PRIORITY 



RESERVED =111 



REGISTER 
POINTER ^ rj, 



I D, I De I D5 I D« I Da I D; I D,Td7| 
I re 1 



] h- 



R250IRQ 
Interrupt Request Register 

(FAh; Read/Write) 

{ D, [ Dfi I D5 [ D4 j D3 1 D; [ 6, I Dp I 



RESERVED (MUST BE 0)- 



- IRQO = P32 INPUT (Do = IRQO) 
IR01 = P33 INPUT 
IRQ2 = P3i INPUT 
IRQ3 = P3o INPUT, SERIAL INPUT 
IRQ4 = To, SERIAL OUTPUT 
IRQ5 = Ti 



R254 SPH 
Stack Pointer 

(FEh; Read/Write) 

JD,|Dg|D5|D,|D3|D;|D,|Do' 



R251 IMR 
Interrupt Mask Register 

(FBh; Read/Write) 

j D^ I Ds I D5 I D4 I D3 [ D; I D, I Dp I ' 



-RESERVED (MUST BE 0) 
-1 ENABLES INTERRUPTS 



R255 SPL 
Stack Pointer 

(FFh; Read/Write) 

j D, I Dg I D5 I D4 I D3 I D2 I D, I Dp ] 



STACK POINTER LOWER 
BYTE (SPp-SPj) 



Figure 13. Control Registers (Continued) 
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OPCODE MAP 



Lower Nibble (Hex) 
7 8 



z 

I 8 
a 



6.5 


6.5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 


6.5 


6.5 


12/10,5 


12/10,0 


6,5 


12/10,0 


6.5 




DEC 


DEC 


ADD 


ADD 


ADD 


ADD 


ADD 


ADD 


LD 


LD 


DJNZ 


JR 


LD 


JP 


INC 




Ri 


IRi 


ri,r2 


ri.lr2 


R2.R1 


IR2,Ri 


Rl,IM 


IRl,IM 


ri.R2 


r2.Rl 


ri.RA 


ccRA 


ri.lM 


ccDA 


ri 




6,5 


6.5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 
































RLC 


RLC 


ADC 


ADC 


ADC 


ADC 


ADC 


ADC 
































Ri 


IRi 


ri.r2 


ri.lr2 


R2.R1 


IR2.R1 


R1.IM 


IRl.lM 
































6,5 


6,5 


6,5 


6,5 


10,5 


10,5 


10.5 


10.5 




INC 


INC 


SUB 


SUB 


SUB 


SUB 


SUB 


SUB 
































, Ri 


iRi 


ri.r2 


ri.lr2 


R2.R1 


IR2.R1 


Rl,IM 


IRl.lM 
































8,0 


6,1 


6,5 


6,5 


10,5 


10.5 


10,5 


10.5 




JP 


SRP 


SBC 


SBC 


SBC 


SBC 


SBC 


SBC 
































IRRi 


IM 


ri.r2 


n.ir2 


R2.R1 


IR2.R1 


Rl,IM 


IR1.IM 
































8,5 


8,5 


6,5 


6,5 


10,5 


10.5 


10,5 


10.5 




DA 


DA 


OR 


OR 


OR 


OR 


OR 


OR 
































Ri 


IRi 


ri.r2 


''I.lr2 


R2.R1 


iR2,Ri 


Rl,IM 


IRl.lM 
































10,5 


10.5 


6,5 


6,5 


10,5 


10,5 


10,5 


10.5 


POP 


POP 


AND 


AND 


AND 


AND 


AND 


AND 
































Ri 


IRi 


ri.r2 


ri,lr2 


R2.R1 


IR2.R1 


R1.IM 


IRl.lM 
































6,5 


6,5 


6,5 


6,5 


10,5 


10,5 


10.5 


10.5 




COM 


COM 


TCM 


TCM 


TCM 


TCM 


TCM 


TCM 
































Ri 


IRi 


ri.r2 


ri.lr2 


R2.R1 


IR2.R1 


R1.IM 


IRl.lM 
































10/12,1 


12/14,1 


6,5 


6,5 


10,5 


10,5 


10.5 


10.5 




PUSH 


PUSH 


TM 


TM 


TM 


TM 


TM 


TM 
































R2 


IR2 


n.r2 


ri.lr2 


R2.R1 


iR2,Ri 


Rl,IM 


IR1.IM 
































10,5 


10,5 


12,0 


18,0 










6.1 


DECW 


DECW 


LDE 


LDEI 






































Dl 


RRl 


IRi 


ri,lrr2 


Iri,lrr2 








































6,5 


6,5 


12,0 


18,0 










6,1 


RL 


RL 


LDE 


LDEI 






































El 


Ri 


IRi 


r2,lrri 


Ir2,lrri 








































10,5 


10,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10.5 


14,0 


INCW 


INCW 


CP 


CP 


CP 


CP 


CP 


CP 






























RET 


RRl 


IRi 


ri.r2 


ri.lr2 


R2.R1 


iR2,Ri 


Rl.lM 


IR1.IM 
































6,5 


6,5 


6,5 


6,5 


. 10,5 


10,5 


10,5 


10.5 


16,0 


CLR 


CLR 


XOR 


XOR 


XOR 


XOR 


XOR 


XOR 






























IRET 


Ri 


IRi 


ri.r2 


'■i.lr2 


R2.R1 


lR2,Ri 


Rl,IM 


IRl.lM 
































6,5 


6,5 


12,0 


18,0 








10.5 


6,5 


RRC 


RRC 


LDC 


LDCI 








LD 






























RCF 


Ri 


IRi 


ri,lrr2 


Iri,lrr2 








ri,x,R2 
































6,5 


6,5 


12,0 


18,0 


20,0 




20,0 


10,5 


6,5 


SRA 


SRA 


LDC 


LDCI 


CALL* 




CALL 


LD 






























SCF 


Ri 


IRi 


r2,lrri 


ir2,lrri 


IRR1 




DA 


r2,x,Ri 
































6,5 


6,5 




6,5 


10,5 


10.5 


10,5 


10,5 


6,5 


RR 


RR 




LD 


LD 


LD 


LD 


LD 






























CCF 


Ri 


IRi 




ri,IR2 


R2.R1 


IR2,Ri 


Rl,IM 


IRl.lM 
































8,5 


8,5 




6,5 




10,5 






6.0 


SWAP 


SWAP 




LD 




LD 


































NOP 


Ri 


IRi 




Iri,r2 




R2-IR1 






y 


f 


\ 


r 


\ 


1 


^ 


f 


) 


r 


\ 


1 


\ 


f 





LOWER 
OPCODE 
NIBBLE 



Bytes per Instruction 



EXECUTION 
CYCLES 



V^ 



PIPELINE 
CYCLES 



UPPER 

OPCODE - 

NIBBLE 



-►A 



10,5 
CP 

R2.R1 



FIRST 
OPERAND 



A^ 



SECOND 
OPERAND 



Legend: 

R = 8-bit address 
r = 4-bit address 
Ri orri = Dst address 
R2 or r2 = Src address 

Sequence: 

Opcode, First Operand. Second Operand 

' NOTE: The blank areas are not defined - 



*2-byte instruction; fetch cycle appears as a 3-byte instruction 
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ABSOLUTE MAXIMUM RATINGS 

Voltages on all pins except RESET 

with respect to GND -0.3V to +7.0V 

Operating Ambient 

Temperature ... .See Ordering Information 

Storage Temperature -65°Cto + 150**C 



Stresses greater than those listed under Absolute Maximum Ratings may 
cause permanent damage to the device. This is a stress rating only; 
operation of the device at any condition above those indicated in the 
operational sections of these specifications is not implied. Exposure to 
absolute maximum rating conditions for extended periods may affect 
device reliability 



STANDARD TEST CONDITIONS 

The DC characteristics listed below apply for the following 
standard test conditions, unless otherwise noted. All 
voltages are referenced to GND. Positive current flows into 
the referenced pin. 

Standard conditions are as follows: 

■ + 4.75V <Vcc< + 5.25V 

■ GND = OV 

■ **C < Ta < + 70 °C for S (Standard temperature) 

■ - 40 "C < Ta < + 1 00 °G for E (Extended temperature) 



FROM OUTPUT f 
UNDER TEST *■ 




2.1 K ^ 



Figure 14. Test Load 1 



DC CHARACTERISTICS 


Symbol 


Parameter 


Min 


Max 


Unit 


Condition 


VCH 


Clock Input High Voltage 


3.8 


Vcc 


V 


Driven by External Clock Generator 


VCL 


Clock Input Low Voltage 


-0.3 


0.8 


V 


Driven by External Clock Generator 


V|H 


Input High Voltage 


2.0 


Vcc 


V 




V|L 


Input Low Voltage 


-0.3 


0.8 


V 




Vrh 


Reset Input High Voltage 


3.8 


Vcc 


V 




Vrl 


Reset Input Low Voltage 


-0.3 


0.8 


V 




VOH 


Output High Voltage 


2.4 




V 


lOH = -250mA 


Vol 


Output Low Voltage 




0.4 


V 


JQL = + 2.0 mA 


l|L 


Input Leakage 


-10 


10 


/^A 


V|N = OV 5.25V 


lOL 


Output Leakage 


-10 


10 


mA 


V|N = OV 5.25V 


l|R 


Reset Input Current 




-50 


yA 


Vcc = + 5.25V Vrl = 0V 


Ice 


Vcc Supply Current 




180 


mA 


All outputs and I/O pins floating 
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Figure 15. External I/O or Memory Read/ Write Timing 



AC CHARACTERISTICS 

External I/O or Memory Read and Write Timing 



Number Symbol 



Parameter 



8 MHz 
MIn Max 



12 MHz 
Min Max 



Notes*!** 



1 


TdA(AS) 


Address Valid to AS t Delay , 




50 




35 




2,3 


2 


TdAS(A) 


AS t to Address Float Delay 




70 




45 




2,3 


3 


TdAS(DR) 


AS t to Read Data Required Valid 






360 




220 


1,2,3 


4 


TwAS 


^ Low Width 




80 




55 




2,3 


5 


TdAz(DS) 


Address Float to DSI 
















6 


TwDSR 


DS (Read) Low Width 




250 




185 




1,2,3 


7 


TwDSW 


DS (Write) Low Width 




160 




110 




1,2,3 


8 


TdDSR(DR) 


DS i to Read Data Required Valid 






200 




130 


1,2,3 


9 


ThDR(DS) 


Read Data to DS t Hold Time 
















10 


TdDS(A) 


DS t to Address Active Delay 




70 




45 




2,3 


11 


TdDS(AS) 


DSttoAS^Delay 




70 




55 




2,3 


12 


TdR/W(AS) 


R/W Valid to AS t Delay 




50 




30 




2,3 


13 


TdDS(R/W) 


DSt to R/W Not Valid 




60 




35 




2,3 


14 


TdDW(DSW) 


Write Data Valid to DS (Write) 1 Delay 




50 




35 




2,3 


15 


TdDS(DW) 


DS t to Write Data Not Valid Delay 




60 




35 




2,3 


16 


TdA(DR) 


Address Valid to Read Data Required Valid 




410 




255 


1,2,3 


17 


TdAS(DS) 


ASttoDSIDelay 




80 




55 




2,3 


NOTES: 

i . When using extended memory timing add 2 TpC. 

2. Timing numbers given are for minimum TpC. 

3. See clock cycle time dependent characteristics table. 


* All units in nanoseconds (ns). 

t Test Load 1 

** All timing references use 2.0V for a Ipgic 


'1" and 0.8V for a logic "0". 
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Figure 16. Additional Timing 



AC CHARACTERISTICS 

Additional Timing Table 









8 MHz 


12 MHz 




Number 


Symbol 


Parameter 


Min 


Max 


MIn 


Max 


Notes* 


1 


TpC 


Input Clock Period 


125 


1000 


83 


1000 


1 


2 


TrCJfC 


Clock Input Rise and Fall Times 




25 




15 


1 


3 


TwC 


Input Clock Width 


37 




70 




• 1 


4 


TwTinL 


Timer Input Low Width 


100 




70 




2 


5 


TwTinH 


Timer Input High Width 


3TpC 




3TpC 




2 


6 


TpTin 


Timer Input Period 


8TpC 




8TpC 




.2' 


7 


TrTin.TfTIn 


Timer Input Rise and Fall Times 




100 




100 


2 


8A 


TwIL 


Interrupt Request Input Low Time 


100 




70 




2,4 


8B 


TwIL 


Interrupt Request Input Low Time 


3TpC 




3TpC 




2,5 


9 


TwIH 


Interrupt Request Input High Time 


3TpC 




3TpC 




2,3 , 



NOTES: 

1 . Clock timing references use 3.8V for a logic "1 " and 0.8V for a logic "0". 

2. Timing references use 2.0V for a logic "1 " and 0.8V for a logic "0". 

3. Interrupt request via Port 3. 

4. Interrupt request via Port 3 (P3i-P33) 

5. Interrupt request via Port 3 (P3o) 
* Units in nanoseconds (ns). 
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Figure 17a. Input Handshake Timing 
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Figure 17b. Output F 
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AC CHARACTERISTICS 














Handshake Timing 














Number 


Symbol 


Parameter 


„. 8 MHz 

Min 


IVIax 


mJ2Mh, 


'IVIax 


Notest* 


1 


TsDI(DAV) 


Data In Setup Time 














2 


ThDI(DAV) 


Data In Hold Time 


230 




160 






3 


TwDAV 


Data Available Width 


175 




120 






4 


TclDAVIf(RDY) 


DAV i Input to RDY 1 Delay 




175 




120 


1,2 


5 


TclDAVOf(RDY) 


DA^I Output to RDY i Delay 












1,3 


6 


TclDAVIr(RDY) 


DAV t Input to RDY t Delay 




175 




120 


1,2 


7 


TdDAVOr(RDY) 


DAV t Output to RDY t Delay 












1,3 


8 


TdDO(DAV) 


Data Out to DAV i Delay 


50 




30 




1 


9 


TdRDY(DAV) 


Rdyi Input to M7t Delay 





200 





140 


1 



NOTES: 

1 . Test load 1 

2. Input handshake 

3. Output handshake 

t All timing references use 2.0V for a logic "1 " and 0.8V for a logic "0", 
* Units in nanoseconds (ns). 



87 



CLOCK CYCLE TIME-DEPENDENT 
CHARACTERISTICS 







8 MHz 


12 MHz 


Number 


Symbol 


Equation 


Equation 


1 


TdA(AS) 


TpC-75 


TpC-50 


2 


TdA${A) 


TpC-55 


TpC-40 


3 


TclAS(DR) 


4TpC-140* 


4TpC-110* 


4 


TwAS 


TpC-45 


TpC-30 


6 


TwDSR 


3TpC-125* 


3TpC-65* 


7 


TwDSW 


2TpC^90* 


2TpC-55* 


8 


TdDSR(DR) 


3TpC-175* 


3TpC-120* 


10 


Td(DS)A 


TpC-55 


TpC-40 


11 


TdDS(AS) 


TpC-55 


TpC-30 


12 


TdR/W(AS) 


TpC-75 


TpC-55 


13 


TdDS{R/W) 


TpC-65 


TpC-50 


14 


TdDW(DSW) 


TpC-75 


TpC-50 


15 


TdDS(DW) 


TpC-55 


TpC-40 


16 


TdA(DR) 


5TpC-215* 


5TpC-160* 


17 


TdAS(DS) 


TpC-45 


TpC-30 



* Add 2TpC when using extended memory timing 



88 



^ZilCG 



PRELIMINARY 
Product Specification 



April 1988 



Z86C08 CMOS Z8 
MICROCONTROLLER 



FEATURES: 

• Complete microcomputer with 18-pin package, 14 

I/O lines, and 2K bytes of on-chip ROM. 

• 142-byte register file, including 124 general purpose 

8-blt registers, 3 I/O port registers, and 15 status 
and control registers. 

• Two programmable 8-bit counter/timers, each with a 

6-bit programmable prescaler. 

• On-chip osillator that accepts a crystal or external 

clock drive. 

• 2 Volt "BROWN OUT" protection. 



• Two analog comparators. 

• Register pointer so that short fast instructions 
access any one of the eight working register groups 

• Internal power on reset. 

• Standby modes - HALT and STOP. 

• 8, 12 MHz 

• CMOS process. 



GENERAL DESCRIPTION: 



The Z86C08 is a 2K ROM version of the Z8 single-chip 
microcomputer housed in an 18-pin DIP. It offers all the 
outstanding features of the Z8 family architecture in a 
low cost plastic DIP for price and size sensitive designs. 



Flexible I/O with low power (1 5mA max, 5mA HALT, 10^A 
STOP) operation makes this an ideal micrcomputer for 
hand-held and consumer applications. It has Instruction 
compatibility with the entire Z8 family for easy software 
migration. 



— ^ 


GND Vcc 
XTAL IN P20 
XTALOUT P21 
P31/An1 P22 
P32/An2 P23 
P33/REF P24 
POO P25 
POl P26 
P02 P27 


< 














w 





















8(1 
9C 



P24 

P25 

P26 

P27 

Vcc 

XTALOUT 

XTAL IN 

P31/An1 



P23 
P22 
P21 
P20 
GND 
P02 
POl 
POO 



P32/An2 P33/REF 



ills 

Hie 
HIS 

1112 

nil 

nio 



Figure 1. Pin Functions 



Figure 2. Pin Assignments 
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PIN DESCRIPTION: 



ARCHITECTURE: 



POo-POg. I/O Port Lines (Inputs/outputs, CMOS compat- 
ible). The three lines of Port are programmable as inputs 
or outputs on a group basis (Figure 3). 
P2o-P27 . I/O Port Lines (inputs/outputs, CMOS compat- 
ible). The eight lines of Port 2 are programmable as inputs 
or outputs on a line by line basis (Figure 3). 
PS^-PSg. Input Port Lines (inputs, CMOS compatible). 
The three lines of Port 3 are programmable as digital or 
analog comparator Inputs on a group basis (Figure 3). 
XTAL IN, XTAL OUT. Crystal In, Crystal Out (time-base 
input and output). These pins connect a parallel-resonant 
crystal (12 MHz maximum) or an external single-phase 
clock (1 2 MHz maximum) to the on-chip clock oscillator 
and buffer. 



Z86C08 architecture is characterized by a flexible I/O 
scheme, an efficient register and address space structure 
and a number of ancillary features that are helpful in many 
applications (Rgure 3). 

Microcomputer applications demand powerful I/O capa- 
bilities. The Z86C08 fulfills this with 14 pins dedicated to 
input and output. These lines are grouped into three I/O 
ports which are configurable under software control. 
Two basic address spaces are available: program memory 
and the internal register file. The register file is composed 
of 124 general purpose 8-bit registers, three I/O port reg- 
isters, and 15 control and status registers. 
To unburden the program from coping with real-time 
problems two counter/timers with a large number of user- 
selectable modes are offered on-chip. 



ADDRESS SPACES: 



Program Memory. The program counter addresses 2K 
bytes of program memory space as shown in Figure 4. 
The first 1 2 bytes of program memory are reserved for the 
interrupt vectors. These locations contain six 1 6-blt vectors 
that correspond to the six available interrupts . 
Register File. The register file includes three I/O port reg- 
isters , 1 24 general purpose registers (R4 - R1 27), and 1 5 
control registers (R240 - R255). These 
registers are assigned the address locations shown In 
Figure 5. 



Instructions can access registers directly or indirectly with 
an 8-bit address field. The Z86C08 also allows short 4-bit 
register addressing using the Register Pointer (one of the 
control registers). In the 4-bit mode, the register file is 
divided into eight working register groups, each occupying 
16 contiguous locations. The Register Pointer addresses 
the starting location of the active working-register group 
(Figure 6). 

STACKS. An 8-bit Stack Pointer (R255) is used for the 
internal stack that resides within the 1 24 general purpose 
registers (R4-R1 27). 



m 



counter; 

TIMERS 
(2) 



2 ANALOG 
COMPARATORS 



^ 



i£ 



il 



i£ 






tttp \n 



^ 



ji 



] 



3> 



PROGRAM 

MEMORY 

204'8 X 8BIT 



21. 



ZJf 



&i 



(BIT PROGRAMMABLE) 

Figure 3. Functional Block Diagram 
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COUNTER/TIMERS: 



I/O P0RT6: 



The Z86C08 contains two 8-blt programmable counter/ 
timers (TO and T1 ), each driven by Its own 6-blt program- 
mable prescaler. The T1 prescaler can be driven by 
internal or external clock sources; however, the TO pres- 
caler is driven by the internal dock only. 
The 6-bit prescalers can divide the input frequency of the 
clock source by any number from 1 to 64. Each prescaler 
drives its counter, which decrement the value (1 to 256) that 
has been loaded into the counter. When the counter 
reaches the end of count, a timer interrupt request - IRQ4 
(TO) or IRQ5 (T1 ) - is generated. 
The counters can be started, stopped, restarted to con- 
tinue, or restarted from the initial value. The counters can 
also be programmed to stop upon reaching zero (single 
pass mode) or to automatically reload the initial value and 
continue counting (modulo-n continuous mode). The 
counters, but not the prescalers, can be read at any time 
without disturbing their value or count mode. 
The clock source for T1 is user-definable and can be 
retriggerable or non-retriggerable, or a gate input for the 
internal clock. 



The Z86C08 has 14 lines dedicated to input and output. 
These lines are grouped into three ports and are configur- 
able as input or output. All ports have active pull-ups and 
pull-downs compatible with CMOS loads. 
Port can be programmed on either inputs or outputs. The 
configuration Is shown in Figure 7. 
Port 2 bits can be programmed independently as input or 
output. In addition. Port 2 can be configured to provide 
open-drain outputs. The configuration is shown In Figure 8. 
Port 3 lines can be configured as digital inputs, analog 
inputs, or control lines. In ail cases, the direction of these 
three lines is fixed as inputs. 

Port 3 can also provide the following control functions: 
four external interrupt request signals<IRQO, IRQ1, IRQ2 
and IRQ3) or timer input signal (TIN). The configuration of 
Port 3 Is shown in Figure 9. 



20 

LOCATION OF 
FIRST BYTE OF 
INSTRUCTION - 

EXECUTED 
AFTER RESET 


48 
\ 

12 

10 
9 
8 

4 

4 
2 



ON-CHIP 
ROM 


>V 




IRQ5 




IRQS 




IRQ4 




IRQ4 


INTERRUPT 


IRCB 


VECTOR V 
(LOWER BYTE) 


IRQS 


■< 


IR02 


INTERRUPT 
VECTOR ' 


ir 


IRQ2 


IRQ1 


(UPPER BYTE) 


1RQ1 




IRQO 




IHQO 



Figure 4. Program Memory Map 



STACK POINTER (BITS 7-0 



REGISTER POINTER 



PROGRAM CONTROL FLAGS 



INTERRUPT MASK REGISTER 



INTERRUPT REQUEST REGISTER 



INTERRUPT PRIORITY REGISTER 



PORTS 0-1 MODE 



PORT 2 MODE 



TO PRESCALER 



TIMER/COUNTER 



T1 PRESCALER 



TIMER/COUNTER 1 



Figure 5. Register File 
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Figure 6. Register Pointer 



Figure 4. Program Memory Map Figure 5. Register File Figure 6. Register Pointer 
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INTERRUPTS: 



The Z86C08 allows six different interrupts from five 
sources: tfie three Port 3 lines P31 - P33, both the rising 
and falling edge of P32 (AN2), the falling edge of P31 
(AN1) and P32 (REF - Figure 9), and the two counter/ 
timers. These interrupts are both maskable and priori- 
tized. The Interrupt Mask Register globally or individually 
enables or disables the six interrupt requests. When more 
than one interrupt is pending, priorities are resolved by a 
programmable priority encoder that is controlled by the 
Interrupt Priority register. 

All Z86C08 interrupts are vectored through locations in 
program memory. When an interrupt request is granted, 
an interrupt machine cycle is entered. This disables all 
subsequent interrupts, saves the Program Counter and 
status flags, and branches to the program memory vector 
location reserved for that interrupt. This memory location 
and the next byte contain the 1 6-bit address of the interrupt 
service routine for that particular interrupt request. 
Polled interrupt systems are also supported. To accom- 
modate a polled structure, any or all of the intermpt inputs 
can be masked and the interrupt request register polled to 
determine which of the interrupt requests needs service. 
Interrupt sources and corresponding intenrupts are shown 
In Table 2. 

STANDBY MODE: 

The Z86C08 has two standby modes which are entered by 
executing either: 

• STOP 



HALT 



The STOP instruction stops the internal clock and external 
crystal oscillation; the HALT instruction 6tops the internal 
clock but not crystal oscillation. 
The STOP mode can be released by two methods. The 
first method is a RESET of the device by removing Vcc. The 
second method is if P27 is configured as an input line when 
the device executes the STOP instruction. A low input 
condition on P27 releases the STOP mode. Program exe- 
cution under both conditions begins at location 
%OOOC(HEX). However, when P27 is used to release the 
STOP mode the I/O port mode registers are not reconfig- 
ured to their default power-on conditions. This prevents any 
I/O, configured as output when the STOP instruction was 
executed, from glitching to an unknown state. 
The HALT mode is released by an interrupt on Port 3 input, 
a time-out in Timer or Timer 1 , or by a RESET of the 
device. To complete an instmction prior to entering standby 
mode,use the instructions: 

NOP 

HALT or STOP 

To use the P27 release approach with STOP mode, use the 
following instructions: 

OR P2,#%80 

NOP 

STOP 

RESET: 

Power-On Reset is in the Z86C08. The Z86C08 waits for 
10 to 25 ms + 18 crystal clocks (Figure 10) while power is 
on, and then Jumps to the starting address %OOOC(HEX). 
The control Register reset value is listed in Table 1 . 
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Figure 7. Z86C08 Port Configuration 
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Figure 8. Z86C08 Port 2 Configuration 



e a DIGIT«. 

1 1 1 1 1 Th ' " 




=/- 



P31 DATA 
LATCH 

IRCe, Tin 



[S>^^ 



^Nv- 



W^ 



P330ATA 
••LATCH 



ZSecOa port 3 CO^FIGURATZON 



Figure 9. Z86C08 Port 3 Configuration 



Table 1. Z86C08 Control Registers 



86C08 


control 


registers : 




Addr. 


reg. 


Reset condition 


Commments 


Fl 


TMR 


00000000 




F2 


Tl 


UUUUUUUU 




F3 


PREl 


UUUUUUOO 




F4 


TO 


UUUUUUUU 




F5 


PREO 


uuuuuuuo 




F6 * 
F7 * 


P2M 
P3M 


11111111 

UUUUUUOO 


Inputs after 
Reset 


F8 * 


POIM 


UUUOUUOl 




F9 


IPR 


UUUUUUUU 




FA 


IRQ 


UUOOOOOO 


IRQ3 is 
used for 
pos. edge 
detection 


FB 


IMR 


OUUUUUUU 




FC 


FLAGS 


UUUUUUUU 




FD 


RP 


00000000 




FE 

FF 


SPH 

SPL 


UUUUUUUU 
UUUUUUUU 


Not used, 
stack always 
internal 



o get out of stop mode 



P3R<0Dld start) 

• 

P2,7 (stop mode) 



lOmsDel^y Line 



CHIP RESET 



Figure 10. Internal Reset Configuration 



Table 2. Interrupt Types, Sources, 


and Vectors 


Source Name 


Vector 
Location 


Comments 


AN2(P3..) IRQ„ 


0,1 External 


i Edge Trig. 


REF(P3JIRQ, 


2,3 External 


V Edge Trig. 


AN1(P3;)IRQ; 


4,5 External 


" Edge Trig. 


AN2(P3, IRQ, 


6,7 External 


, . Edge Trig. 


TO IRQ. 


8,9 Internal 




Tl IRQ, 


10,11 Internal 
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WATCH DOG TIMER (WDT): 



The Watch Dog Timer (WDT) should be refreshed within 
15 ms. If not refreshed, then the Z86C08 resets itself. 

WDT: 5F(HEX). 
CLOCK: 

The on-chip oscillator has a high-gain, parallel-resonant 
amplifier for connection to a crystal, ceramic resonator, or 
to any suitable external clock source (XTAL IN = Input, 
XTAL OUT = Output). 



The crystal source is connected across XTAL IN and XTAL 
OUT, using the recommended capacitors (Cl = 1 5 pF) from 
each pin to ground. The specifications for the crystal are 
as follows: 

• AT cut, parallel resonant 

• Fundamental type, 12 MHz max 

• Series resistance, RS< 100 ohm 

The oscillator configuration is shown in Figure 11. 



XTAL IN 



5M Ohm 



XTAL OUT 



i/2 DIVIDER 



XTAL CLOCK 



SYSTEM CLOCK 



Figure 11 . Z86C08 Crystal Input Config. 



PORT 3 COMPARATORS: 



The 86C08's port 3 inputs include two analog comparators 
for added interface flexibility. Interrupts are generated on 
either edge of comparator 2's output, or on the falling edge 
of comparator 1's output The block diagram is shown in 
Figure 9. , Comparator outputs may be used for interrupt 
generation, Port 3 data inputs, or Tin in the case of ANT 
(P31). Alternatively, the comparators may be disabled, 
freeing the reference input (P33) for use as IRQ1 and/or 
P33 input. 



The dual comparator (common inverting terminal) fea- 
tures a single power supply which discontinues power in 
stop mode. The common voltage range is 0-4 V; the power 
supply and common mode rejection ratios are 90db and 
60db, respectively. See comparator specif Icatlons for de- 
tails (Page 16). 

Typical applications for the on-board comparators include: 
zero crossing detection, analog-to-digital conversion, volt- 
age scaling, and threshold detection. 
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INSTRUCTION SET NOTATION 



Addressing Modes. The following notation is used to 
describe the addressing nnodes and instruction operations 
as shown in the instruction summary. 

IRR Indirect register pair or indirect working-register 

pair address 

Irr Indirect working-register pair only 

X Indexed address 

DA Direct address 

RA Relative address 

IM Immediate 

R Register or working-register address 

r Working-register address only 

IR Indirect-register or indirect working-register 

address 

Ir Indirect working-register address only > 

RR Register pair or working register pair address 

Symbols. The following symbols are used in describing the 
instruction set. 

dst Destination location or contents 

src Sou roe location or contents 

cc Condition code (see list) 

@ Indirect address prefix 

SP Stack pointer (control registers 254-255) 

PC Program counter 

FLAGS Flag register (corttrol register 252) 

RP Register pointer (control register 253) 

IMR Interrupt mask register (control register 251) 



Assignment of a value is indicated by the symbol "*-". For 
example, 

dst "*- dst -I- src 

indicates that the source data is added to the destination 
data and the result is stored in the destination location. The 
notation "addr(n)" is used to refer to bit "n" of a given 
location. For example, 

dst (7) 

refers to bit 7 of the destination operand. 

Flags. Control Register R252 contains the following six 
flags: 

C 

z 
s 

V 
D 
H 



Carry flag 
Zero flag 
Sign flag 
Overflow flag 
Decimal-adjust flag 
Half-carry flag 

Affected flags are indicated by: 

Cleared to zero 

1 Set to one 

* Set or cleared according to operation 

— Unaffected 

X Undefined 



CONDITION CODES 



Value 


Mnemonic 


Meaning 


Flags Set 


1000 




Always true 


— 


0111 


c 


Carry 


= 1 


1111 


NO 


No carry 


= 


0110 


Z 


Zero 


Z = 1 


1110 


.NZ 


Not zero 


Z = 


1101 


PL 


Plus 


8 = 


0101 


Ml 


Minus 


8 = 1 


0100 


OV 


Overflow 


V = 1 


1100 


NOV, 


No overflow 


V = 


0110 


EQ 


Equal 


Z = 1 


1110 


NE 


Not equal 


Z = 


1001 


GE 


Greater than or equal 


(8X0RV) = 


, 0001 


LT 


Less than 


(8 XOR V) = 1 


1010 


GT 


Greater than 


[Z OR (S XOR V)] = 


0010 


LE 


Less than or equa^ 


[ZOR(SXORV)] = 1 


1111 


UGE 


Unsigned greater than or equal 


C = 


0111 


ULT 


Unsigned less than 


C = 1 


1011 


UGT 


Unsigned greater than 


(C = OANDZ = 0) = 1 


0011 


ULE 


Unsigned less than or equal 


(CORZ)= 1 


0000 




Never true 


— 
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INSTRUCTION FORMATS 



OPC MODE 



dst/src OPC 



dst/CC I OPc" 



CCF, Dl, El, IRET, NOP, 
RCF, RET, SCF 



OPC I INCr 

One-Byte Instructions 



OR (l 


1 1 1 dst/src 1 




OR [l_ 


1 1 0| dst 1 



OPC 


MODE 


dst 


src 



CLR, CPL, DA, DEC, 
DECW, INC, INCW, POP, 
PUSH, RL, RLC, RR, 
RRC, SRA, SWAP 

JP, CALL (Indirect) 



ADC, ADD, AND, 
CP, OR, SBC, SUB, 
TCM, TM, XOR 



MODE 


OPC 


dst/src 


src/dst 



OR |1 1 1 0| src I 



OPC I MODJ" 



OPC I MODE 



I OPC 



DAu 



1110 


src 


1110 


dst 



ADC, ADD, AND, CP, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 



ADC, ADD, AND, CP, 



OR ii 1 1 oi dst I LD, OR, SBC, SUB, 
OR 1^ ^ ^ °l °s* I TCM, TM, XOR 



1110 


src 


1110 


dst 



MODE 


OPC 


dst/src 


X 


ADDRESS 



Two-Byte instructions 



Three-Byte Instructions 



Figure 12, Instruction Formats 



INSTRUCTION SUMMARY 



Instruction 
and Operation 




AddrMode 


Opcode 
Byte 
(Hex) 


Flags Affected 


dst src 


C Z S V D H 


ADC dst,src 

dst *- dst + src + 


C 


(Note1) 


in 


* * * * * 


ADD dst.src 
dst *- dst + src 




(Note1) 


on 


* * * * * 


AND dst,src 

dst -dst AND src 




(Note1) 


■ SD 


- * * 


CALL dst 

SP-SP - 2 
@SP - PC; PC - 


dst 


DA 
IRR 


D6 
D4 




CCF 

C-NOTC 






EF 


* 


CLR dst 

dst-0 




R 
IR 


BO 
B1 




COM dst 

dst*- NOT dst 




R 
IR 


60 
61 


- * * - - 


CP dst, src 
dst - src 




(Note1) 


AD 


* * * * 



DA dst 

dst *- DA dst 
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R 
IR 



40 
41 



* * * X 



Instruction 
and Operation 


Addr Mode 


Opcode 
Byte 
(Hex) 


Flags Affected 


dst 


src 


C Z S V D H 


DEC dst 

dst *- dst - 1 


R 
IR 




00 
01 


— * * * 


DECW dst 

dst *- dst - 1 


RR 
IR 




80 
81 


— * * * 


Dl 

IMR(7)-0 






8F 





DJNZ rdst 
r-r - 1 
ifr^O 

PC - PC + dst 
Range: +127, -128 



RA 



El 

IMR(7)^ 



HALT 



rA 
= - 



9F 



7F 



INC dst 


r 


rE 


dst — dst + 1 




r = 0-F 




R 


20 




IR 


21 


INCW dst 


RR 


AO 


dst - dst + 1 


IR 


A1 



* * * 



INSTRUCTION SUMMARY (Continued) 



instruction 
and Operation 


AddrlVlode 
dst src 


Opcode 
Byte 
(Hex) 


Fiags Affected 


C Z S V D H 


IRET 

FLAGS - @SP; SP - 
PC-@SP;SP-SP 


-SP4- 1 

+ 2;IMR(7) 


BF 
-^1 


****** 


JP ccdst 
if cc is true 
PC *- dst 


DA 
IRR 


cD 

c = 0-F 

30 





JR ccdst 




RA 




if cc is true, 








PC - PC + 


dst 






Range: +127, 


-128 






LD dst,src 




r 


Im 


dst *- src 




r 


R 






R 


r 






r 


X 






X 


r 






r 


Ir 






Ir 


r 






R 


R 






R 


IR 






R 


IM 






IR 


IM 






IR 


R 



LDC dst, src 
dst ^ src 




r 
Irr 


Irr 
r 


r? 




D2 




LDCi dst,src 

dst *- src 

r*-r + 1; rr*-rr 


+ 1 


Ir ■ 
Irr 


Irr 
Ir 


r'^ 




D3 




LDEdst,src 
dst *- src 




r 
Irr 


Irr 
r 


RO 
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LDEI dst,src 

dst ^ src 

r *- r + 1 ; rr ^ rr 


+ 1 


Ir 
Irr 


Irr 
Ir 


ft"^ 
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NOP 








pp 








OR dst,src 

dst *- dst OR src 




(Note 


'1) 


4n - * * - 


— 


POP dst 

dst *- @SP; 
SP*-SP + 1 




R 
IR 




RO 




51 




PUSH src 

SP-SP - 1;@SP- 


src 


R 
IR 


7n 




71 




RCF 

C-0 








CF 


— 


RET 

PC-@SP;SP- 


-SP- 


+ 2 




AF 












R 
IR 




90 * * * * — 

91 




RL dst 1 


1 


— 


m-HEi 


o|J 











Instruction 
and Operation 


AddrlVlode 
dst src 


Opcode 
Byte 
(Hex) 


Flags Affected 
C Z S V D H 


nn . , 


^ 


EG 
El 




RR dsl 1 1 


I^IR 


* * * * 


Ljc| L|, 












CO 
CI 




RRC dsl 1 


^JlR 


* * * * 


SBC dst, src 

dst *- dst ^ src ^ C 


(Notel) 


3n 


* * * * 1 * 


SCF 

C*-1 




DF 


1 






DO 
D1 




SRAdstC^ 


-'^IR 


* * * 


1 4 4 




SRP src 

RP *- src 


Im 


31 




STOP 




6F 




SUB dst,src 
dst *- dst ^ src 


(Notel) 


2n 


* * * * 1 * 


SWAP dst + 


.,, ", ID 


FO 
F1 


X * * X 


1 


j— ^IR 




TCIVI dst, src 
(NOT dst) AND src 


(Notel) 


en 


- * * 


TIVI dst,src 
dst AND src 


(Notel) 


7n 


- * * 


WDT 




5F 




XOR dst,src 

dst *- dst XOR src 


(Notel) 


BD 


- * * 



cB 
c = 0- F 

rC 
r8 
r9 
r = - F 
C7 
D7 
E3 
F3 
E4 
E5 
E6 
E7 
F5 

NOTE. These instructions have an identical set of addressing modes, 

which are encoded for brevity. The first opcode nibble is found in 
the instruction set table above. The second nibble is expressed 
symbolically by a □ in this table, and its value is found in the 
following table to the left of the applicable addressing mode pair 
For example, the opcode of an ADC instruction using the 
addressing modes r (destination) and Ir (source) is 13. 

Addr IVIode 
Lower 

dst src Opcode Nibble 

[2] 

Ir [3] 

R R [±\ 

R IR - [5] 

R IM [e] 

IR IM [7] 



RLC dst 



[^|l£ 



3-J|R 



10 

11 
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OPCODE MAP 



Lower Nibble (Hex) 
6 7 8 






65 


65 


6,5 


6.5 


10,5 


10.5 


10,5 


10,5 


65 


*6.5 


12/10.5 


12/10,0 


65 


,12/10.0 


"65 




DEC 


DEC 


ADD 


ADD 


ADD 


ADD 


ADD 


ADD 


LD 


LD 


DJNZ 


JR 


LD 


JP 


INC 




f^i 


iRi 


ri,r2 


'ri,lr2 


R2R1 


IR2.R1 


R1.IM 


IRi IM 


ri,R2 


r2.Rl , 


r, RA 


ccRA 


ri IM 


ccOA 


r1 




65 


65 


6,5 


6,5 


10,5 


10.5 


10,5 


10,5 
































RLC 


RLC 


ADC 


ADC 


ADC 


ADC 


ADC 


ADC 
































Ri 


IRv 


ri.r2 


ri.lr2 


R2.R1 


IR2,Ri 


Ri IM 


IRl.lM 
































65 


6,5 


6.5 


6,5 


10.5 


10,5 


10,5 


10,5 




INC 


INC 


SUB 


SUB 


SUB 


SUB 


SUB 


SUB 
































Ri 


IRi 


h-f2 


ri,lr2 


R2.R1 


IR2.R1 


Ri,!M 


IR1.IM 
































80 


6.1 


6.5 


6.5 


10,5 


10,5 


105 


10,5 




JP 


SRP 


SBC 


SBC 


SBC 


SBC 


SBC 


SBC 
































IRRi 


IM 


ri.r2 


ri.lr2 


R2.R1 


IR2.R1 


Ri IM 


IRl,IM 
































8,5 


85 


6.5 


6.5 


10,5 


10.5 


10.5 


10.5 




DA 


DA 


OR 


OR 


OR 


OR 


OR 


OR 
































Ri 


IRi 


ri.r2 


ri.lr2 


R2.R1 


IR2,Ri 


R1.IM 


IRi.lM 
































10.5 


10.5 


6.5 


6,5 


10,5 


10,5 


10,5 


10.5 




POP 


POP 


AND 


AND 


AND 


AND 


AND 


AND 






























6.0 


Ri 


IRi 


ri.r2 


ri.li'2 


R2,Ri 


IR2.R1 


Ri,IM 


IRi.lM 
































65 


6,5 


6.5 


6,5 


10.5 


10,5 


10,5 


. 10,5 


6.0 


COM 


COM 


TCM 


TCM 


TCM 


TCM 


TCM 


TCM 






























srop 


Ri 


IRi 


ri r2 


nlr2 


R2.R1 


IR2.R1 


Ri.lM 


IRi,IM 
































10/12,1 


12/14,1 


, 65 


6,5 


10,5 


10,5 


10,5 


10,5 


7,0 


PUSH 


PUSH 


TM 


TM 


TM 


TM 


TM 


TM 






























HALT 


R2 


IR2 


ri.r2 


ri,lr2 


R2.R1 


IR2.R1 


Ri,IM 


IRl,IM 
































10.5 


10,5 














6 1 


DECW 


DECW 








































Dl 


RRl 


IRi 












































65 


6,5 














6 1 


RL 


RL 










































El 


Ri 


IRi 












































10.5 


10.5 


6.5 


6,5 


10,5 


10,5 


10,5 


10.5 


140 


INCW 


INCW 


CP 


CP 


CP 


CP 


CP 


CP 






























RET 


RRl • 


IRi 


rir2 


rilr2 


R2.R1 


IR2R1 


Ri IM 


IRi.lM 
































6,5 


6.5 


6.5 


6,5 


10,5 


10,5 


10,5 


10,5 


160 


CLR 


CLR 


XOR 


XOR 


XOR 


XOR 


XOR 


XOR 






























IRET 


Ri 


iRi 


-ri.rs 


ri,lr2 


R2.R1 


IR2.R1 


Ri IM 


tRi,IM 
































6,5 


6,5 


12,0 


18.0 








10,5 


6.5 


RRC 


RRC 


LDC 


LDCI 








LD 






























RCF 


Ri 


IRi 


ri,lrr2 


Iri,lrr2 








ri,xR2 
































6,5 


6.5 


12,0 


18,0 


20,0 




20.0 


10,5 


65 


SRA 


SRA 


LDC 


LDCI 


CALL* 




CALL 


LD 






























SCF 


Ri 


IRi 


r2,irri 


Ir2,lrri 


IRR1 




DA 


r2.xRi 
































6,5 


6.5 




6,5 


10.5 


10,5 


10,5 


10,5 


6,5 


RR 


RR 




LD 


LD 


LD 


LD 


LD 






























CCF 


Ri 


iRi 




ri,IR2 


R2.R1 


IR2,Ri 


Ri,IM 


IRl,IM 
































85 


8,5 




6,5 




10.5 






60 


SWAP 


SWAP 




LD 




LD 


































NOP 


Ri 


IRi 




Iri,r2 




R2,IRi 






\ 


' 


\ 


r 


\ 


r 


1 


r 


\ 


L 


\ 


1 


1 


r 





LOWER 
OPCODE 
NIBBLE 



Bytes per Instruction 



EXECUTION 
CYCLES 



V^ 



PIPELINE 
CYCLES 



UPPER 
OPCODE- 
^NIBBLE 



10,5 
CP 

R2.R1 



A^ 



SECOND 
OPERAND 



Legend: 

R * 8-bit address 

r = 4-bit address 

Ri orr-i = Dst address , 

R2 or r2 = Src aQdress 

Sequence: 

Opcode, First Operand, Second Operand 

NOTE: The blank areas are not defined. 



*2-t>yte instruction, fetch cycle appears as a 3-byte instrudtion 
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R241 TMR 
TIMER MODE REGISTER 

(F1h; Read/Write) 



X— J 



DelD; 



Tin mooes 
EXTERNAL CLOCK INPUT = 00 
GATE INPUT = 01 
TRIGGER INPUT = 10 - 
(NON-RETRIGGERABLE) 

TRIGGER INPUT = 11 
(RETRIGGERABLE) 



D4 I Da I D; I D, [ Dp I 



L" 



R245 PREO 
PRESCALER REGISTER 

(F5h; Write Only) 



I D7 I Ds I Ds I P4 I D3 I D2 I Di \oI\ 



COUNT MODE 
- = To SINGLE PASS 
1 = To MODULON 



PRESCALER MODULO 
-(RANGE: 1-64 DECIMAL 
01-00 HEX) 



R242 T1 
COUNTER TIMER 1 REGISTER 

■ (F2h; Read/Write) 

j D7 I De I Ds I D4 I Da I D; I D, I Dp I 



R246 P2M 
PORT 2 MODE REGISTER 

(F6h, Write Only) 



Oe D5 D4 Pa D2 



\EM 



T, CURRENT VALUE (WHEN READ) 



P2oP27 I/O DEFINITION 
- DEFINES BIT AS OUTPUT 
1 DEFINES BIT AS INPUT 



R243 PRE1 
PRESCALER 1 REGISTER 

(F3h, Write Only) 



I D7 [ De I D5 D4 [ D3 [_D; I D, I Dp I 



L 



COUNT MODE 

T, SINGLE-PASS 
1 = T, MODULON 

CLOCK SOURCE 
_ 1 = T, INTERNAL 

= T, EXTERNAL TIMING INPUT 
(Tin) MODE 

PRESCALER MODULO 
-(RANGE: 1-64 DECIMAL 
01-00 HEX) 



R247 P3M 
PORT 3 MODE REGISTER 

(F7h; Write Only) 

I D7 I De I D5 [ D4 I D3 1 D; I D| I Dp j 



PORT 3 INTERRUPTS 
-0 DIGITAL 
1 ANALOG 



R244 TO 
COUNTER/TIMER REGISTER 

(F4h, Read/Write) 

I D7 I De I D5 1 D4 I D3 I D; I D, I Dp I 



Tp INITIAL VALUE (WHEN WRITTEN) 

-(RANGE 1 256 DECIMAL 01 00 HEX) 

Tp CURRENT VALUE (WHEN READ) 



NOTE: All "don't care" bits return a "1 " when read. 



Figure 16 Control Registers 
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R248P01M 
PORT AND 1 MODE REGISTER 

(FSh: Write Only) 


1 D, 1 Oe 1 Ds 1 D4 1 D3 


d.|o,|do| 


X— J 




PO0-PO3 MODE 

00 = OUTPUT 

01 = INPUT 

Y 






MUST BE 



R252 FLAGS 
FLAG REGISTER 

(FCh; Read/Write) 



I D7 I Og I Dg I D« I D3 I D; 



EH 

Li: 



USER FLAG ^1 

USER FLAG F2 
-HALF CARRY FLAG 
-DECIMAL ADJUST FLAG 
-OVERFLOW FLAG 
-SIGN FLAG 
-ZERO FLAG 
-CARRY FLAG 



R249 IPR 
INTERRUPT PRIORITY REGISTER 

(F9h; Write Only) 



I Dy j De j D5 j D« j D3 I D; ! D, j Dp j 



IRQ3, IRQ5 PRIORITY (GROUP A) 

= IRQ5 > IRQ3 - 

1 = IRQ3 > IRQ5 

IRQO, IRQ2 PRIORITY (GROUP B) 

= IRQ2 > JRQO - 

1 = IRQO > IRQ2 

IRQ1, IRQ4 PRIORITY (GROUP C) 

= IRQ1 > IRQ4 - 

1 = IRQ4 > IRQ1 



INTERRUPT GROUP PRIORITY 



RESERVED = 


000 


C > A > B = 


001 


A > B > C = 


010 


A > C > B = 


Oil 


B > C > A = 


100 


C > B > A = 


101 


B > A > C = 


110 


RESERVED := 


111 



R253 RP 
REGISTER POINTER 

(FDh; Read/Write) 

|D7[D6|D5|D4|D3|DjD,|Doi 



J 



-DON'T CARE 



R250 IRQ 
INTERRUPT REQUEST REGISTER 

(FAh, Read/Write) 



E 



De D5 D4 D3 D2 



Kl 



IRQO - P32 INPUT 
IRQ1 - P33 INPUT 
. IRQ2 . P31 INPUT 
IRQ3 - P32 INPUT 
IRQ4 - TO 
IRQS.T1 



R255 SPL 
STACK POINTER 

(FFh: Read/Write) 

I D, j Dg j D5 I D4 I D3 j D; j DiTdT] 



STACK POINTER LOWER 
BYTE (SP0-SP7) 



R251 IMR 
INTERRUPT MASK REGISTER 

(FBh; Read/Write) 

I Py I Pe I D5 ! D4 I D3 I D; j D, I d7J 



- RESERVEP 

-1 ENABLES INTERRUPTS 



Figure 16 Control Registers (Continued) 
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ABSOLUTE MAXIMUM RATINGS 



Voltages on all pins with respect 

toGND -0.3V to +7.0V 

Operating Ambient 

Temperature See Ordering Information 

Storage Temperature -65°Cto +150°C 



Stresses greater than those listed under Absolute Maximum Ratings may 
cause permanent damage to the device. This is a stress rating only; 
operation- of the device at any condition above those indicated in^the 
operational sections of these specifications is not implied.. Exposure to 
absolute maximum rating conditions for extended periods may affect 
device reliability. 



STANDARD TEST CONDITIONS 

The DC characteristics listed below apply for the following 
standard test conditions, unless otherwise noted. All 
voltages are referenced to GND. Positive current flows into 
the referenced pin ( Figure 13). 

Standard conditions are as follows: 

■ +4.5V<_Vcc<_+5.5V 

■ GND = OV 

■ 0°C<Ta< +70°C 



FROM OUTPUT , 




Figure 1 a Test Load 1 



Z86C0808PSC DC CHARACTERISTICS V^ = 3.0 to 5.5V 0°C to 70°C 



Symbol Parameter 



Min 



Typ 



Max 



Unit 



Condition 



Max input Voltage -QVcc 

Clock Input High Voltage 

Clock Input Low Voltage -0.3 

Input High Voltage .7V^ 

Input Low Voltage -0.3 



12.0 

Vcc+0.3 
.1Vcc 

.2Vcc 



V 

V 
V 
V 
V 



«,N 250mA^ 
Driven by external CG 
Driven by External CG 



V«H 


RESET Input High Voltage 


•7V«, 

cc 


Vcc+0.3 


V 




Vr, 


RESET Input Low Voltage 


-0.3 


•2V^ 


V 




VoH 


Output High Voltage 


Vcc-0.4 




V 


\^ = -2.0mA 


Vci 


Output Low Voltage 




0.4 


V 


'oL = +'*OrnA 


Vol. 


Output Low Voltage 




0.8 


V 


\^^ = +12mA, 3 pins max. 



input Leakage 
Output Leakage 
RESET Input Current 
Supply Current 
Standby Current 
Standby Current 



-10 
-10 



-10 



10 uA V„^OV.V,, 

10 uA V,,=OV.V,, 

-50 uA V^c = 4.5 to 5.5V. V^^ = ^V, 

1 5 mA All Output & I/O pins float 

5 mA HALTMode^ V„-OV. V^^ 

10 uA STOP Mode V = OV, V.^ 



P27 



Note: 

1. led Typ. Max. 

Clock driven on XTAL 0.3 mA 5.0,mA 

Resonator or Crystal 3.0mA 5.0mA 
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Z86C0808PEC DC CHARACTERISTICS 


Vee 


= 3.0 to 5.5V -40°Cto 


+105°C 


Symbol 


Parameter 


Min Typ 




Max Unit 


Condition 



Max Input Voltage 

V^^ Clock Input High Voltage .9Vcc 
V^L Clock Input Low Voltage -0.3 

V,^ Input Higtv Voltage 0.7Vcc 
V,^^ Input Low Voltage -0.3 



12.0 

Voc+0.3 

•IVcc 

Vcc^-0.3 



.2V, 



cc 



V 

V 
V 
V 
V 



l„ 250mA 

Driven by external CG 
Driven by External CG 



Vbh 


RESET Input High Voltage 


.7V^ 


V,,+0.3 


V 




Vr, 


RESET Input Low Voltage 


-0.3 


■2V,, 


V 




VoH 


Output High Voltage 


Vcc-0-4 




V 


\^ = -2.0mA 


Von 


Output' Low Voltage 




0.4 


V 


Iqj^ =: +4. 0mA 


Vot. 


Output Low Voltage 




0.8 


V 


loL'=+12mA, 3pinsmax. 



I,L Input Leakage 


-10 


Iql Output Leakage 


-10 


l,P RESET Input Current 




l^c Supply Current 




Iqq^ Standby Current 




\qq^ Standby Current 





10 uA V„ = OV.V,, 

10 uA V„ = OV,V, 

-10 -50 uA V^c = 4.5 to 5.5V, VpL = OV, 

1 5 mA All Output & I/O pins float 

5 mA HALTMode^ V^=OV, V^c 

20 uA STOP Mode V = OV, V^^ 



P27 



Note: 

1. led Typ. Max. 

Clock driven on XTAL 0.3mA 5.0mA 

Resonator or Crystal 3.CmA 5.0mA 



I- © — ^3>-^| 

■""V—J — \ /^> / — \_ 




Figure 14. Additional Timing 
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AC CHARACTERISTICS 



Number Symbol Parameter 



Min 



Max 



Notes 



1 


TpC 


2 


TrC, TfC 


3 


TwC 


4 


TwTlnL 


5 


TwTinH 



Input Clock Period 1 25 
Clock Input Rise and Fall Times 
Input Clock Width 37 

Timer Input Low Width 1 00 

Timer Input High Width 3TpC 



100,000 
25 



1 
1 
1 
2 
2 



6 TpTin Timer Input Period 8TpC 

7 TrTin,TfTin Timer Input Rise and Fall Times 

8A TwIL Int. Resquest Input Low Time 100 

9 TwIH Int. Request Input High Time 3TpC 



100 



2 
2 

2,4 
2,3 



NOTES: 

1. Clock timing references use V^cfor a logic "1" and Vgg for logic "0". 

2. Timing references use V^c for a logic "1" and V33 for a logic "0". 

3. Interupt request via P31 - P33 

4. Interrupt request via P31 -P33 

*Units in nanoseconds (ns) 



PRELIMINARY Z86C08 COMPARATOR SPECIFICATIONS 





CASE 1 


CASE 2 


CASE 3 


CASE 4 


CASE 5 


\Conditions 
Parameters^ 


VDD=2.5V 
Temp=40C° 


VDD=2.5V 
Temp=85C<^ 


VDD=5.5V 
Temp=40C^ 


VDD=5.5V 
Temp=85C° 


VDD=5 . OV 
Temp=27C^ 


Offset 
Voltage (mv) 


_^50 (est) 


.+50 (est) 


_+50 (est) 


.+50 (est) 


.^25 (typ) 


Internal 
Delay Time (us) 
Overdrive (mv) 


15 (max) 
.+300 


15 (max) 
.+300 


1 . (max) 
.+300 


1.0 (max) 
.+300 


0.1 (typ) 
.+300 


Isias (ma) 

Power (mw) 


0.1 (max) 
0.25 


. 1 (max) 
0.25 


1.0 (max) 
5.5 


1.0 (max) 
4.125 


0.2 (typ) 
1.25 


Power Down 


Yes 


Yes 


Yes 


Yes 


Yes 
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ORDERING INFORMATION 

Z86C08 CMOS Microcontroller 
Z86C0808PSC 8MHz 
Z86C0812PSC 12MHz 

Codes 

First letter is for package; second letter is for temperature. 



C = Ceramic DIP 

P = Plastic DIP 

L = Ceramic LCC 

V = Plastic PCC 



R = Protopack 

T = Low Profile Protopack 

DIP = Dual-ln-Line Package 

LCC = Leadless Chip Carrier 

PCC = Plastic Chip Carrier (Leaded) 



TEMPERATURE 
S = OXto +70°C 
E = -40°Cto +85°C 
M*= -55°Cto+125°C 



FLOW 

B = 883 Class B 

J = JAN 38510 Class B 



Example: PS is a plastic DIP, 0°C to + 70°C. 



PACKAGE DIMENSIONS 



NOTE: 

0.031 RADIUS - 

NOTCH ALT. 



0.300 
0.320 



S 



, 0.325 
k— ".025— * 
-.015 



0.100 
0.025 
0.030—1 
0.065 — j 



MAX 




0.050 
±.015 



\*~ r-*\\*— 0.100—1 h^ 
I 0.016 I' TYP ' I 

0.003 



125 
MIN 



18-Pln Plastic Package 

NOTE: Package dimensions are given m inches. To convert to nnillimeters, multiply by 25.4, 
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^ZilDG 



ADVANCED INFORMATION 
Product Specification 



Z86C00/C10/C20CMOS 
Z8®MCU 



August 1989 



FEATURES 



Complete microcomputer, 2K (86C00), 4K (86C10), or 8K 
(86C20) bytes of TOM, 1 24 bytes of RAM (256 bytes - Z86C20), 
and 22 I/O lines. 



Register Pointer so that short, fast instructions can 
access any of nine working— register groups in 1.0 
us. 



144-byte register file, Including 124 (238 - Z86C20) general- 
purpose registers, four I/O port registers, and 1 4 status and control 



Average instruction execution time of 1.5 us, 
maximum of 2.8 us. 

Vectored, priority interrupts for I/O and 
counter/timers. 

Two programmable 8-bit counter/timers, each with 
a 6-bit programmable prescaler. 



■ On— chip oscillator which accepts crystal, external 
clock drive, LC, ceramic resonator. 

■ Standby modes — — Halt and Stop. 

■ Single +5V power supply — all pins TTL- 
compatible. 

■ 8 and 12 MHz 

■ CMOS process. 



GENERAL DESCRIPTION 



Z86C10/C20 microcomputer (Figures 1 and 2) introduces a- 
new level of sophistication to single-chip architecture. 
Compared to earlier single-chip microcomputers, the 



Z86C10/C20 offers faster execution; more efficient use of 

memory; more sophisticated interrupt, input/output and 

, bit-manipulation capabilities; and easier system expansion. 



TIMING 

AND 

CONTROL 



PORT 2 < 



RESET +5V 

DS XTAL1 

POo XTAL2 

POi P3i 

P02 Z86C00 ^^^ 
"""^ MCU 
""^ Z86C10 
"^^ MCU 
""^^ Z86C20 
MCU 



P22 
P23 
P24 
P25 
GND 



> PORT 1 




Figure 1 . Pin Functions 



Figure 2. Pin Assignments 
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PIN DESCRIPTIONS 



DS. Data Strobe (output, active Low). Data Strobe is 
activated once for each memory transfer. 

PO0-PO5, P1o-Pl7, P2rP25, P3i, P35, PSe- I/O Port lines 
(bidirectional/ TTL-compatible). These 22 I/O lines are 
grouped in four ports that can be configured under program 
control for I/O. 



RESET. Re set (inp ut, active Low). RESET initializes the 
MOD. When RESET is deactivated, program execution 
begins from internal program location OOOCh- 

XTAL1, XTAL2. Crystal 1, Crystal 2 (time-base input and 
output). These pins connect a parallel-resonant 
crystal to the on-chip clock oscillator and buffer 



ARCHITECTURE 

The MOD'S architecture is characterized by a flexible I/O 
scheme, an efficient register and address space structure, 
and a number of ancillary features that are helpful in many 
applications. (Figure 3). 

Microcomputer applications demand powerful I/O 
capabilities. The MCU fulfills this with 22 pins dedicated to 
input and output. These lines are grouped in four ports and 
are configurable under software control to provide timing, 
status signals, and parallel I/O. 



Two basic internal address spaces are available to support 
this wide range of configurations: program memory and the 
register file. The 144-byte random-access register file is 
composed of 124 general-purpose registers, four I/O port 
registers, and 1 4 control and status registers. 

To unburden the program from coping with real-time 
■problems such as counting/timing, two counter/timers with 
a large number of user-selectable modes are offered 
on-chip. 



OUTPUT INPUT 

it I 



COUNTER/ 

TIMERS 

(2) 



INTERRUPT 
CONTROL 



i£ 



id 



Itttt 



Vcc GND 



iE 



REGISTER 
POINTER 



REGISTER FILE 
124 X 8BIT 



TE 



i£ 



^ 



XTAL DS RESET 

tt t I 



MACHINE TIMING AND 
INSTRUCTION CONTROL 



3 



H 



PROGRAM 

MEMORY 

4096 X 8-BIT 



TF 



PROGRAM 
COUNTER 



<^ 



31 



W^ ^ 



(8192 for C20) 



(BIT PROGRAMMABLE) (BYTE PROGRAMMABLE) 

Figure 3. Functional Bioclc Diagram 



STANDBY MODE 

The Z86C00/C10/C20's standby modes are: 

■ Stop 

■ Halt 

The Stop instruction stops the internal clock and clock 
oscillation; the Halt instruction stops the internal clock but 
not clock oscillation. 



A reset input releases the standby mode. 

To complete an instruction prior to entering standby mode, 
use the instructions: 

LD TMR, #00 

NOP 

STOP or HALT 
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ADDRESS SPACES 



Program Memory. The 16-bit program counter addresses 
4K or 8K bytes of program memory space as shown in 
Figure 4. 

The first 1 2 bytes of program memory are reserved for the 
interrupt vectors. These locations contain three 16-bit 
vectors that correspond to the three available interrupts. 

Register File. The 144-byte register file includes four I/O 
port registers (R0-R3), 124 general-purpose registers 
(R4-R127) and 15 control and status registers (R24rR255)- 
These registers are assigned the address locations shown in 
Figures. 



Instructions can access registers directly or indirectly with, 
an 8-bit address field. The MCU also allows short 4-bit 
register addressing using the Register Pointer (one of the 
control registers). In the 4-bit mode, the register file is 
divided into nine working-regi,ster groups, each occupying 
16 contiguous locations (Figure 6). The Register Pointer 
addresses the starting location of the active working-register 
group. 

Stacks. An 8-bit Stack Pointer (R255) is used for the internal 
stack that resides within the 124 general-purpose registers 
(R4-Ri27)- 



LOCATION OF 

FIRST BYTE OF 

INSTRUCTION 

EXECUTED 

AFTER RESET 



INTERRUPT 

VECTOR 

(LOWER BYTE) 



INTERRUPT 

VECTOR 

(UPPER BYTE) 



4096 


ON-CHIP 
ROM 


12 


3^ 


11 


IRQ5 


10 


IRQ5 




IRQ4 




IRQ4 




RESERVED 




RESERVED 


*. 


IRQ2 


^ 


If 


IRQ2 


RESERVED 


2 


RESERVED 


1 


RESERVED 





RESERVED 



Figure 4. Program Memory IVIap 



LOCATION 




IDENTIFIERS 


255 


STACK POINTER (BITS 7-0) 


SPL 


254 


RESERVED 




253 


REGISTER POINTER 


RP 


252 


PROGRAM CONTROL FLAGS 


FLAGS 


251 


INTERRUPT MASK REGISTER 


IMR 


250 


INTERRUPT REQUEST REGISTER 


IRQ 


249 


INTERRUPT PRIORITY REGISTER 


IPR 


248 


PORTS 0-1 MODE 


r>01M 


247 


PORT 3 MODE 


P3M 


246 


PORT 2 MODE 


P2M 


245 


TO PRESCALER 


PREd 


244 


TIMER/COUNTER 


TO 


243 


T1 PRESCALER 


PRE1 


242 


TIMER/COUNTER 1 


T1 


241 


T4MER MODE 


TMR 




NOT 
IMPLEMENTED 




127 
4 


GENERAL-PURPOSE 
REGISTERS 




3 


PORT 3 


P3 


2 


PORT 2 


P2 


1 


PORT 1 


P1 





PORTO 


PO 



. _». I ^7 re rg r4 



THE UPPER NIBBLE OF THE REGISTER FILE ADDRESS 
- PROVIDED BY THE REGISTER POINTER SPECIFIES 
THE ACTIVE WORKING-REGISTER GROUP 



SPECIFIED WORKING- 
REGISTER GROUP 



THE LOWER 
NIBBLE OF 
THE REGISTER 
FILE ADDRESS 
- PROVIDED BY 
THE INSTRUCTION 
POINTS TO THE 
SPECIFIED 
REGISTER. 



Figure 5. Register File 



Figure 6. Register Pointer 
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COUNTER/TIMERS 



The MCU contains two 8-bit programnnable counter/timers 
(To and T-i), each driven by its own 6-bit programmable 
prescalen The T-| prescaler can be driven by internal or 
external clock sources; however, the Tq prescaler is driven 
by the internal clock only. 

The 6-bit prescalers can divide the input frequency of the 
clock source by any number from 1 to 64. Each prescaler 
drives its counter, which decrements the value (1 to 256) that 
has been loaded into the counter. When the counter reaches 
the end of count, a timer interrupt request— IRQ4 (Tq) or 
I RQ5 (Ti)— is generated. 

The counters can be started, stopped, restarted to continue, 
or restarted from the initial value. The counters can also be 
programmed to stop upon reaching zero (single-pass 



mode) or to automatically reload the initial value and 
continue counting (modulo-n continDous mode). The 
counters, but not the prescalers, can be read any time 
without disturbing their value or count mode. 

The clock source for Ti is user-definable and can be the 
internal microprocessor clock ~ divided by 

four, or an external signal input via Port 3. The Timer Mode 
register configures the external timer input as an external 
clock , a trigger input that can be 

retriggerable or non-r^triggerable, or as a gate input for the 
internal clock. The counter/timers can be programmably 
cascaded by connecting the Tq output to the input of Ti '. 
Port 3 line P36 also serves as a timer output (Tqut) through 
which Tq, Ti or the internal clock can be output. 



I/O PORTS 



The MCU has 22 lines dedicated to input and output 
grouped in four ports. Under software control, the ports can 
be programmed to provide address outputs, timing, status 
signals, and parallel I/O. All ports have active pull-ups and 
pull-downs compatible with TTL loads. 

Port can be programmed as an I/O port. 

Port 1 can be programmed as a byte I/O port. 



Port 2 can be programmed independently as input or 
output and is always available for I/O operations. In addition, 
Port 2 can be configured to provide open-drain outputs. 

Port 3 can be configured as I/O or control lines. PS^ is a 
general purpose input or can be used for an external 
interrupt request signal (IRQ2)- P35 and P36 are general 
purpose outputs. P36 is also used for timer input (Tin) and 
output (Tout) signals. 



INTERRUPTS 



The MCU allows three different interrupts from three 
sources, the Port 3 line P3i and the two counter/timers. 
These interrupts are both maskable and prioritized. The 
Interrupt Mask register globally or individually enables or 
disables the three interrupt requests. When more than one 
interrupt is pending, priorities are resolved by a 
programmable priority encoder that is controlled by the 
Interrupt Priority register. 

All interrupts are vectored. When an interrupt request is 
granted, an interrupt machine cycle is entered. This disables 



all subsequent interrupts, saves the Program Counter and 
status flags, and branches to the program memory vector 
locations reserved for that interrupt. This memory location 
and the next byte contain the 1 6-bit address of the interrupt 
service routine for that particular interrupt request. 

Polled interrupt systems are also supported. To accom- 
modate a polled strupture, any or all of the interrupt inputs 
can be masked and the Interrupt Request register polled to 
determine which of the interrupt requests needs service. 



CLOCK 



The on-chip oscillator has a high-gain parallel-resonant 
amplifier for connection to a crystal or to any suitable 
external clock source (XTAL1 = Input, XTAL2 = Output). 

Crystal source is connected across XTAL1 and XTAL2 using 
the recommended capacitors (C1 < 1 5 pf) from each pin to 
ground. The specifications are as follows: 



AT cut, parallel resonant 

Fundamental type, 16 MHz maximum. 

Series resistance, Rs < 1 00 n 
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INSTRUCTION SET NOTATION 



Addressing Modes. The following notation is used to 
describe the addressing modes and instruction operations 
as shown in the instruction summary. 

[RR Indirect register pair or indirect working-register 

pair address 

Irr Indirect working-register pair only 

X Indexed address 

DA Direct address 

RA Relative address 

IM Immediate 

R Register or working-register address 

r Working-register address only 

IR Indirect-register or indirect working-register 

address 

Ir Indirect working-register address only 

RR Register pair or working register pair address 

Symbols. The following symbols are used in describing the 
instruction set. 

dst Destination location or contents 

src Source location or contents 

cc Condition code (see list) 

@ Indirect a^Jdress prefix 

SP Stack pointer (control registers 254-255) 

PC Program counter 

FLAGS Flag register (control register 252) 

RP . Register pointer (control register 253) 

IMR Interrupt mask register (control register 251 ) 



Assignment of a value is indicated by the symbol "*-". For 
example, 

dst *- dst + src 

indicates that the source data is added to the destination 
data and the result is stored in the destination location. The 
notation "addr(n)" is used to refer to bit "n" of a given 
location. For example, 

dst (7) 

refers to bit 7 of the destination operand. 

Flags. Control Register R252 contains the following six 
flags: 



c 


Carry flag 


z 


Zero flag 


s 


Sign flag 


V 


Overflow flag 


D 


Decimal-adjust flag 


H 


Half-carry flag 


Affected flags are indicated by: 





Cleared to zero 


1 


Set to one 


* 


Set or cleared according to operation 


— 


Unaffected 


X 


Undefined 



CONDITION CODES 


Value Mnemonic 


Meaning 


Flags Set 


1000 




Always true 


— 


0111 


C 


Carry 


C = 1 


1111 


NO 


No carry 


C = 


0110 


z 


Zero 


Z = 1 


1110 


NZ 


Not zero 


z = o 


1101 


PL 


Plus 


8 = 


0101 


Ml 


Minus 


8 = 1 


0100 


ov 


Overflow 


V = 1 


1100 


NOV 


No overflow 


V = 


' 0110 


EQ 


Equal 


Z = 1 


1110 


NE 


Not equal 


Z = 


1001 


GE 


Greater than or equal 


(8XORV) = 


0001 


LT 


Less than 


(8X0RV) = 1 


1010 


GT 


Greater than 


[Z OR (8 XOR V)] = 


0010 


LE 


Less than or equal 


[Z0R(8X0RV)] = 1 


1111 


UGE 


Unsigned greater than or equal 


C = 


. 0111 


ULT 


Unsigned less than 


C = 1 


1011 


UGT 


Unsigned greater than 


(C = OANDZ = 0) = 1 


0011 


ULE 


Unsigned less than or equal 


(CORZ) = 1 


0000 




Never true 
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INSTRUCTION FORMATS 



J 



COF, Dl, El, IRET, NOP, 
RCF, RET, SCF 



OPC I INC r 

One-Byte instructions 



OPC MODE 



CLR, CPL, DA, DEC, 



dsj/src °R| ii.o|d..,s.c | °^tZZh^%'°'- 



dst/srcl OPC 



dst I OPc" 



dst/CCj OPC 



RRC, SRA, SWAP 
JP, CALL (Indirect) 



OR |1 1 1 q| dst I 



OPC 


MODE 


dst 


src 



MODE 


OPC 


dst/src 


src/dst 



ADC, ADD, AND, , 
CP, OR, SBC, SUB, 
TCM, TM, XOR 



LD, LDC, LOCI 



OR |1 1 1 0| src I 



DJNZ, JR 



OPC I mode" 



OPC I MODE 



MODE I OPc" 



I OPC 



1110 


src 


1110 


dst 



OR |T 



1 101 dst 



MODE 


OPC 


dst/src 


X 


ADDRESS j 



ADC, ADD, AND, CP, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 



ADC, ADD, AND, CP, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 



1110 


src 


1110 


dst 



Two-Byte instructions 



Three-Byte instructions 



Figure 7. Instruction Formats 



INSTRUCTION SUMMARY 



instruction 
and Operation 




AddriVlode 


Opcode 
Byte 
(Hex) 


Flags Affected 


dst src 


C Z S V D H 


ADC dst.src 

dst *- dst + src + 


C 


(Note1) 


in 


* * * * * 


ADD dst, src 
dst *- dst + src 




(Note1) 


on 


* * * * * 


ANPdst.src 

dst ^ dst AND src 




(Note1) 


5n 


- * * 


CALL dst 

SP-SP-2 
,@SP - PC; PC *- 


dst 


DA 
IRR 


D6 
D4 




CCF 

C-NOTC 






EF 


* '' 


CLR dst 

dst-0 




R 
iR 


BO 
B1 




COIVI dst 

dst*- NOT dst 




R 
IR 


60 
61 


- * * 



Instruction 
and Operation 


AddriVlode 


Opcode 
Byte 
(Hex) 


Flags Affected 


dst 


src 


C Z S V D H 


CP dst.src 
dst - src 


(Note1) 


AD 


* * * * 


DA dst 

dst *- DA dst 


R 
IR 




40 
• 41 


* * * X 


DEC dst 

dst *- dst - 1 


R 
IR 




00 
01 


— * * * 


DECW dst 

dst ^ dst - 1 


RR 
IR 




80 
81 ' 


— * * * 


Dl 

IMR(7)^0 






8F 





DJNZ r,dst RA 


rA 


r^r - 1 


r = - F 


ifr#0 




PC ^ PC + dst 




Range: +127,-128 
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INSTRUCTION SUMMARY (Continued) 



Instruction 
and Operation 


AddrMode 
dst src 


HI 


Flags Affected 


Z S V D H 


Ei 

IMR(7)^1 




9F 




HALT 




7F 





INC dst 

dst *- dst + 1 



R 
IR 



rE 

r = - F 

20 

21 



INCW dst RR 

dst-dst+1 IR 




AO 
A1 




— * * * 


IRET 

FLAGS *-@SP;SP*-SP + 1 
PC *- @SP; SP ^ SP + 2; IMR (7) 


^ 


BF 

1 




****** 


JP cc.dst DA 
if cc is true 
PC -dst IRR 


c 


cD 

= 0- 

30 


F 





JR ccdst 
if cc is true, 

PC - PC + dst 
Range: +127,-128 



RA 



LD dst, src 
dst -^ src 



r 
r 
R 

r 

X 
r 

Ir 
R 
R 
R 
IR 
IR 



Im 
R 

r 

X 

r 

Ir 
r 

R 
IR 
IM 
IM 
R 



cB 
c = - F 

rC 
r8 
r9 
r = 0- F 
C7 
D7 
E3 
F3 
E4 
E5 
E6 
E7 
F5 



LDCdst.src 
dst *- src 




r . 
Irr 


Irr 
r 


C2 
D2 










LDCI dst, src 

dst — src 

r — r + 1 ; rr - 


■ rr + 1 , 


Ir 
Irr 


Irr 
Ir 


C3 
D3 










LDE dst.src 
dst ^ src 




r 
Irr 


Irr 

r 


82 
92 










'LDEI dst, src 
dst — src 
r — r + 1 ; rr *- 


■rr + 1 


Ir 
Irr 


Irr 

Ir 


83 
93 










NOP 








FF 










OR dst, src 

dst ^ dst OR src 


(Notel) 


4n 


- * * - 





POP dst 

dst *- @SP; 
SP-SP + 1 




R 
IR 




50 
51 











PUSH src 

SP<-SP- 1; 



R 

- src IR 



70 
71 



AddrMode 


Opcode 
Byte 
(Hex) 


Flags Affected 


Instruction 

and Operation dst src 


C Z S V D H 


RCF 

c*-o 


CF 





RET 

PC-@SP;SP-SP + 2 


AF 






90 
91 




RLdst 1 1 R 


* * * * 


\o\Mr ofJ 








RLC dst 1 1 R 


10 
11 


* * * * 


LjcH^ oMiR 






EO 
El 




RR dsl 1 1 1 R 


* * * * 


L|c| L|. „g ,p 








^_^ , r^ 


CO 
CI 




RRC dsl 1 1 R 


* * * * 


SBCdst.src (Notel) 
dst *- dst *- src *- C 


3D 


* * * * 1 * 


SCF 

C-1 


DF 


1 




DO 
D1 




SRAdstL^^^H' 


* * * 


'1 'i'i IR 




SRP src Im 

RP *- src 


31 




STOP 


6F 




SUBdstsrc (Notel) 
dst — dst *- src 


2n 


* * * * 1 * 


SWAP dst r~l ' R 

r , T , **] in 


FO 
F1 


X * * X 


1 j IH 




TCMdst,src (Notel) 
(NOT dst) AND src 


en 


- * * 


TMdst,src (Notel) 
dst AND src 


7n 


- * * 


XORdst,src (Notel) 
dst *- dst XOR src 


BD 


- * * 



NOTE: These instructions have an identical set of addressing modes, 

which are encoded for brevity. The first opcode nibble is found in 
the instruction set table above. The second nibble is expressed 
symbolically by a D in this table, and its value is found in the 
following table to the left of the applicable addressing mode pair 
For example, the opcode of an ADC instruction using the 
addressing modes r (destination) and Ir (source) is 1 3. 



Addr Mode 



dst 



Lower 
Opcode Nibble 



r 
r 

R 
R 
R 
IR 



r 

Ir 
R 
IR 
IM 
IM 





H 
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REGISTERS 



R244 TO 
COUNTER/TIMER REGISTER 

(F4h; Read/Write) 

|D,|De|D5|D4|D3|D2|PrrDn 



To CURRENT VALUE (WHEN READ) 



R241 TMR 
TIMER MODE REGISTER 

(F1h; Read/Write) 



R245 PREO 
PRESCALERO REGISTER 

(F5h; Write Only) 



Tout MODES 

NOT USED = 00 

To OUT = 01 

T, OUT = 10 

INTERNAL CLOCK OUT == 11 

T,N MODES 

EXTERNAL CLOCK INPUT = 00 

GATE INPUT = 01 

TRIGGER INPUT = 10 

(NONRETRIGGERABLE) 

TRIGGER INPUT = 11 
(RETRIGGERABLE) 



fo, 


DeJDs 


D4|D3lD2|D,|Do| 












L 











iD/lOelDs 



_ = DISABLE To COUNT 
1 = ENABLE Tg COUNT 



COUNT MODE 
- = To SINGLE PASS 
1 = To MODULON 



PRESCALER MODULO 
-(RANGE: 1-64 DECIMAL 
01-00 HEX) 



R242T1 
COUNTER TIMER 1 REGISTER 

(F2h; Read/Write) 



D, Ds Dj D4 -Dj 



|D2|Pi|p.I 



R246 P2M 
PORT 2 MODE REGISTER 

(F6h; Write Only) 

|D,[Dg|D5|D4|D3|Da|D,|Do| ■ 



T, CURRENT VALUE (WHEN READ) 



P2o-P27 I/O DEFINITION 
- DEFINES BIT AS OUTPUT 
1 DEFINES BIT AS INPUT 



R243 PRE1 
PRESCALER 1 REGISTER 

(F3h; Write Only) 



|PHPe|D5 



D4[d3|d2[d, ^DqI 



count mode 
- = t, single-pass 
1 = t, modulon 

clock source 
_ 1 = t, internal 
= ti external timing input 
(t,n) mode 

prescaler modulo 
-(range: 1-64 decimal 



R247 P3M 
PORT 3 MODE REGISTER 

(F7h; Write Only) 

I D^ I Dg I D5 I D4 I D3 I D; I D^ I Dp I 



- RESERVED (must be 0) 



Figure 1 1 . Control Registers 
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REGISTERS (Continued) 



R248P01M 
PORT AND 1 MODE REGISTER 

(F8h; Write Only) 



PO4-PO7 MODE 
OUTPUT = 00 
INPUT = 01 



T 



T 



PO0-PO3 MODE 

00 = OUTPUT 

01 = INPUT 



- RESERVED (must be = 1) 

PI0-PI7 MODE 
00 = BYTE OUTPUT 
= BYTE INPUT 



i;:}p 



R252 FLAGS 
FLAG REGISTER 

(FCh; Read/Write) 

|D7|De|D5[D4|D3|D^|D,|Dol 



^: 



USER FLAG F1 

USER FLAG F2 
-HALF CARRY FLAG 
-DECIMAL ADJUST FLAG 
-OVERFLOW FLAG 



-ZERO FLAG 
-CARRY FLAG 



R249 IPR 
INTERRUPT PRIORITY REGISTER 

(F9h; Write Only) 



I D7 [ Dg I D5 I D4 D3 I D; I D, I Dp I 



IRQ3, IRQS PRIORITY (GROUP A) 

= IRQS > IRQ3 - 

1 = IRQS > IRQS 

IRQO, IRQ2 PRIORITY (GROUP B) 

= IRQ2 > IRQO - 

1 = IRQO > IRQ2 



IRQ1, IRQ4 PRIORITY (GROUP C) 

= IRQ1 > IRQ4 - 

1 = IRQ4 > IRQ1 



INTERRUPT GROUP PRIORITY 


RESERVED = 


000 


C > A > B = 


001 


- A > B > C = 


010 


A > C > B = 


011 


B > C > A = 


100 


C> B>A = 


101 


B > A > C = 


110 


RESERVED = 


111 



R253 RP 
REGISTER POINTER 

(FDh; Read/Write) 

|D7|De|Ds|D4iD3| D.|D,|Do| 



\^ 



R250 IRQ 
INTERRUPT REQUEST REGISTER 

(FAh; Read/Write) 



|D7|Dg[D5|D4|D3JDa[D, [Do"] 



-IRQ2 = P31 Input 

- IRQ* = To 

- IRQ5 = Tj 



R251 IMR 
INTERRUPT MASK REGISTER 

(FBh; Read/Write) 

|d7[d6[d5JD4|d3|D;|d, IdTI 



R255 SPL 
STACK POINTER 

(FFh; Read/Write) 

|D7|D6|D5|D4[D3|D;|P, [DqI 



. STACK POINTER LOWER 



- 1 ENABLES INTERRUPTS 



Figure 1 1 . Control Registers (Continued) 
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OPCODE MAP 



Lower Nibble (Hex) 
6 7 8 9 



-65 


65 


65 


65 


105 


105 


' 105 


10,5 


6,5 


6,5 


12/105 


12/10,0 


65 


12/100 


65 




DEC 


DEC 


ADD 


ADD 


ADD 


ADD 


ADD 


ADD 


LD 


LD 


DJNZ 


JR 


LD 


JP 


INC 




Ri 


IRi 


ri r2 


ri Ir2 


R2.R1 


IR2.R1 


Ri IM 


IRl,IM 


ri.R2 


r2 Ri 


riRA 


cc.RA 


ri IN/1 


ccDA 


ri 





65 


65 


6.5 


6,5 


10,5- 


10.5 


10,5 


, 10,5 






























RLC 


RLC 


ADC 


ADC 


ADC 


ADC 


ADC 


ADC 
































Ri 


IRi 


ri r2 


ri.lr2 


R2.R1 


IR2.R1 


Rl,IM 


IRl,IM 
































6,5 


6,5 


65 


65 


10,5' 


10.5 


10.5 


10,5 




mc 


INC 


SUB 


SUB 


SUB 


SUB 


SUB 


SUB 
































Ri 


iRi 


ri.r2 


ri,lr2 


R2.R1 


IR2.R1 


Rl IM 


tRl,iM 
































80 


61 


6.5 


6,5 


10,5 


10.5 


10.5 


10,5 




, JP 


SRP 


SBC 


SBC 


SBC 


SBC 


SBC 


SBC 
































IRRi 


IM 


ri.r2 


ri.lr2 


R2.R1 


IR2.R1 


R1.IM 


IRi,IM 
































85 


8.5 


6.5 


6,5 


10,5 . 


10,5 


10.5 


10,5 




DA 


DA 


OR 


OR 


OR 


OR 


OR 


OR 
































Ri 


iRi 


ri.r2 


ri.lr2 


R2.R1 


IR2.R1 


R1.IM 


IRl.lM 
































10.5 


10.5 


6.5 


6,5 


10,5 ■ 


10,5 1 


10,5 


10,5 




POP 


POP 


AND 


AND 


AND 


AND 


AND 


AND 
































Ri 


IRi 


ri,r2 


ri,lr2 


R2.R1 


IR2.R1 


Rl,IM 


IRi.lM 
































6.5 


65 


6,5 


6,5 


10,5 


10,5 


10.5 


10,5 


6,0 


COM 


COM 


TCM 


TCM 


TCM 


TCM 


TCM 


TCM 






























STOP 


Ri 


IRl 


ri,r2 


ri.lr2 


R2.R1 


' IR2.R1 


Rl,IM 


IRl.lM 






























7.0 


10/12,1 


12/14,1 


6.5 


6,5 


10,5 


10,5 


10,5 


10,5 


PUSH 


PUSH 


TM 


TM 


TM 


TM 


TM 


TM 






























HALT 


R2 


IR2 


■ ri,r2 


ri,lr2 


R2.R1 


IR2,Ri 


Rl,IM 


IRl.lM 
































10,5 


10,5 














6 1 


DECW 


DECW 










































Dl 


RRl 


IRi 












































6.5 


6.5 














6,1 


RL 


RL 










































El 


Ri 


IR1 












































10.5 


10,5 


6,5 


6,5 


10,5 


10.5 


10.5 


10,5 


140 


INCW 


INCW 


CP 


CP 


CP 


CP 


CP 


CP 






























RET 


RRl 


IRi 


ri.r2 


ri,lr2 


R2.R1 


IR2.R1 


R1.IM 


lfil,IM 
































6.5 


6,5 


6,5 


6,5 


10,5 


10.5 


10,5 


10,5 


160 


CLR 


CLR 


XOR 


XOR 


XOR 


XOR 


XOR 


XOR 






























IRET 


Ri 


IRi 


ri,r2 


ri,lr2 


R2.R1 


IR2.R1 


R1.IM 


IRl,IM 
































6.5 


6,5 


12,0 


18,0 








- 10,5 


6,5 


RRC 


RRC 


LDC 


LDCI 








LD 






























RCF 


Ri 


IRi 


ri.lrr2 


Iri,lrr2 








ri,x R2 
































6.5 


6,5 


12,0 


18,0 


20,0 




20,0 


10,5 


65 


SRA 


SRA 


LDC 


LDCI 


CALL* 




CALL 


LD 






























SCF 


Ri 


IRi 


r2.lrri 


Ir2,irri 


tRRi 




DA 


r2,x,Ri 
































6.5 


6,5 




6,5 


10,5 


10,5 


10,5 


10,5 


6,5 


RR 


RR 




LD 


LD 


LD 


LD 


LD 






























CCF 


Ri 


IRi 




ri,IR2 


R2.R1 


IR2.R1 


Ri IM 


IRl,IM 
































8.5 


8,5 




6,5 




10,5 






60 


SWAP 


SWAP 




LD 




LD 


































NOP 


Ri 


IR1 




Iri.r2 




R2.IR1 






\ 


r 


1 


r 


1 


r 


1 


r 


1 


r 


\ 


r 


1 


f^ 





Bytes per instruction 



LOWER 
OPCODE 
NIBBLE 



EXECUTION 
CYCLES 



V^^ 



PIPELINE 
CYCLES 



UPPER 

OPCODE - 

NIBBLE 



10,5 
CP 

R2.R1 



FIRST 
OPERAND 



A^ 



SECOND 
OPERAND 



Legend: 

R = 8-bit address 
r = 4-bit address 
Ri orr-i = Dst address 
R2 or r2 = Src address 

Sequence: 

Opcode, First Operand, Second Operand 

NOTE: The blank areas are not defined. 



*2-byte instruction, fetch cycle appears as a 3-byte instruction 
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ABSOLUTE MAXIMUM RATINGS 

Voltages on all pins with respect 

toGND -0.3V to +7.0V 

Operating Ambient 

Temperature See Ordering Information 

Storage Temperature -65°Cto +150°C 



Stresses greater than those listed under Absolute Maximdm Ratings may 
cause permanent damage to the device. This is a stress rating only; 
operation of the device at any condition above those indicated in the 
operational sections of these specifications is not implied. Exposure to 
absolute maximum rating conditions for extended periods may affect 
device reliability. 



STANDARD TEST CONDITIONS 

The DC characteristics listed below apply for the following 
standard test conditions, unless otherwise noted. All 
voltages are referenced to GND. Positive current flows into 
the referenced pin. 

Standard conditions are as follows: 

■ +4.5<Vcc<+5.5 

■ GND = OV 

■ 0°C<Ta< +70°C 



FROM OUTPUT , 
UNDER TEST '' 



150pF?fc 



Figure 12. Test Load 1 




DC CHARACTERISTICS 



Symbol 


Parameter 


Min Typ 


Max 


Unit 


Condition 


VCH 


Clock Input High Voltage 


3.8 


Vcc 


V 


Driven by External Clock Generator 


VCL 


Clock Input Low Voltage 


-0.3 


0.8 


V 


Driven by External Clock Generator 


V|H 


Input High Voltage 


2.0 


Vcc 


V 




V|L 


Input Low Voltage 


-0.3 


0.8 


V 




Vrh 


Reset Input High Voltage 


3.8 


Vcc 


V 




Vrl 


Reset Input Low Voltage 


-0.3 


0.8 


V 




VOH 


Output High Voltage 


2.4 




V 


Ioh=-250mA 


VOH 


Output High Voltage 


Vcc -100 mV 




V 


'oh =-100jiA 


Vol 


Output Low Voltage 




0.4 


V 


Iql = +2.0nnA 


l|L 


Input Leakage 


-10 


10 


mA 


OV<V|N< + 5.25V 


lOL 


Output Leakage 


-10 


10 


mA 


OV<V|N< + 5.25V 


l|R 


Reset Input Current 




-50 


mA 


Vcc= +5.25VVrl = 0V 


'cc 


Supply Current 




50 


mA 


All outputs and I/O pins floating 


icci . 


Standby Current 


5 




mA 


Halt Mode 


ICC2 


Standby Current 




10 


mA 


Stop Mode 



NOTC: 



Icc2 low power requires loading TMR (%F1) 
with any value prior to stop execution. 
Use sequence: 

LDTMR, #%00. 

NOP 

STOP 
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-<!>- 



-Q)-^\ 



"V-^TW^iCTwr^ 




Figure 14. Additional Timing 



AC CHARACTERISTICS 

Additional Timing Table 











Z86C10 




Number 


Symbol 


Parameter 


Min 


Max 


Notes* 


1 


TpC 


Input Clock Period , 


83 


100,000 


1 


2 


TrC.TfC 


Clock Input Rise and Fall Times 




15 


1 


3 


TwC 


Input Clock Width 


70 




1 


4 


TwTinL 


Timer Input Low Width 


70 




2 


5 


TwIL 


Interrupt Request Input Low Time 


70 




2,3 



NOTES: 

1 . Clock timing references use 3.8V for a logic "1" and 0.8V for a logic "0". 

2. Timing references use 2.0V for a logic "1" and 0.8V for a logic "0". 

3. Interrupt request via Port 3. 
* Units in nanoseconds (ns). 
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^ZiK3G 



Product Specification 



Z86C11 CMOS 
Z8® 4K ROM MCU 



June 1987 



FEATURES 



Complete microcomputer, 4K bytes of ROM, 256 bytes of 
RAM, 32 I/O lines, and up to 60K bytes addressable 
external space each for program and data memory 

256 -byte register file, including 236 general-purpose 
registers, four I/O port registers, and 16 status and 
control registers. 

Vectored, priority interrupts for I/O, counter/timers, and 
UART. 

Full-duplex UART and two programmable 8-bit counter/ 
timers, each with a 6-bit programmable prescaler 



I Register Pointer so that short, fast instructions can 
..access any of 16 working-register groups in 1 .5 /iS. 

I On-chip oscillator which accepts crystal or external clock 
drive. 

I Standby modes— Halt and Stop 

I Single "+ 5V power supply— all pins TTL-compatible. 

I 12 MHz, 16 MHz 

I CMOS process 



GENER/^L DESCRIPTION 



The Z86C1 1 microcomputer (Figures 1 and 2) introduces a 
new level of sophistication to single-chip architecture. 
Compared to earlier single-chip microcomputers, the 



Z86C11 offers faster execution; more efficient use of 
memory; more sophisticated interrupt, input/output and 
bit-manipulation capabilities; and easier system expansion. 



TIMING 

AND 

CONTROL 



PORTO 

(NIBBLE , 
PROGRAMMABLE) 

I/O OR Aa-Av 



PORT 1 

(BYTE 
PROGRAMMABLE) 

I/O OR AD0-AD7 



RESET 

R/W 

DS 

AS 

POo 

PO1 

PO2 

PO3 

PO4 

POs 

POe 

PO7 

PI0 

PI1 

PI, 



Z86C11 
MCU 



+ 5V 

GND 

XTAL1 

XTAL2 

P2o 

P2i 

P22 

P23 

P24 

P25 

P26 
P27 

P3o 
P3i 

P32 

P33 
P34 

P35 

P36 

P37 



PORT 2 

(BIT PRO- 
GRAMMABLE) 

I/O 



PORT 3 

SERIAL AND 
PARALLEL I/O 
AND CONTROL 







\y 




+ 5V [^ 


1 


^^ 40 


JP3. 


XTAL2 C 


2 


39 


3P3, 


XTAL1 Q 


3 


38 


3-^> 


P37I: 


4 


37 


3P2. 


P3oC 


5 


36 


]P25 


RESET [^ 


6 


35 


3P2. 


R/W c 


7 


34 


3P23 


DSC 


8 


33 


]P2a 


A-SC 


9 


32 


3«. 


P3sL 


10 


Z86C11 31 


DP2. 


GND ^ 


11 


•**^" 30 


3P33 


P3. C 


12 


29 


]P3. 


POoC 


13 


28 


3P1r 


PO. C 


14 


27 


3p'. 


PO2 c 


15 


26 


2"> 


PO3 c 


16 


25 


3". 


P04 c 


17 


24 


3 PI. 


POsC 


18 


23 


3p'. 


poec: 


19 


22 


3p'. 


PO7 c 


20 


21 


3P1. 



Figure 2. 40-pin Dual-ln-Line Paclcage (DIP), Pin Assignments 
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Under program control, the Z86G11 can be tailored to the 
needs of its user. It can be configured as a stand-alone 
microcomputer with 4K bytfes of internal ROM, a traditional 
microprocessor that rhanages up to 120K bytes of external 



memory, or a parallel-processing element in a system with 
other processors and peripheral controllers linked by the 
Z-BUS® bus. In all configurations, a large number of pins 
remain available for I/O. , 



FIELD PROGRAMMABLE VERSION 

The Z86E11 is a pin compatible "one time 
programmable" version of the Z86C1 1 . The Z86C1 1 
contains 4K bytes of EPROM memory in place of the 
4K bytes of masked ROM in the Z86C11. The 
Z86E11 also contains a programmable memory 



protect feature to provide program security by 
disabling all external accesses to the internal EPROM 
array. This is preliminary information, and Is subject to 
change. 



ARCHITECTURE 



Z86C11 architecture is characterized by a flexible I/O 
scheme, an efficient register and address space structure 
and a number of ancillary features that are helpful in many 
applications. 

Microcomputer applications demand powerful I/O 
capabilities. The Z86C1 1 fulfills this with 32 pins dedicated 
to input and output. These lines are grouped into four ports 
of eight lines each and are configurable under software 
control to provide timing, status signals, serial or parallel I/O 
with or without handshake, and an address/data bus for 
interfacing external memory. 

Because the multiplexed address/data bus is merged with 
the l/0-oriented ports, the Z86C11 can assume many 
different memory and I/O configurations. These config- 
urations range from a self-contained microcomputer to a 



microprocessor that can address 120K bytes of external 
memory (Figure 3). 

Three basic address spaces are available to support this 
wide range of configurations: program memory (internal 
and external), data memory (external) and the register file 
(internal). The 256 -byte random-access register file is 
composed of 236 general-purpose registers, four I/O port 
registers, and 1 6 control and status registers. 

To unburden the program from coping with real-time 
problems such as serial data communication and 
counting/timing, an asynchronous receiver/transmitter 
(UART) and two counter/timers with a large number of 
user-selectable modes are offered on-chip. Hardware 
support for the UART is minimized because one of the 
on-chip timers supplies the bit rate. 



OUTPUT ir^PUT 



Vcc GND 



ttttllll I I 



COUNTER/ 

TIMERS 

(2) 



INTERRUPT 
CONTROL 



H 



5 



2E 



REGISTER 
POINTER 



IS 



^ 



XTAL AS DS R/W RESET 

tit It, I 



MACHINE TIMING AND 
INSTRUCTION CONTROL 



REGISTER FILE 
25ft x 8-BIT 



] 



5T 



PROGRAM 

MEMORY 

4096 X 8-BIT 



Jl. 



PROGRAM 
COUNTER 



3T 



<^ 



Ak 



mm Wi^ e 



I/O ADDRESS OR I/O 

(BIT PROGRAMMABLE) (NIBBLE PROGRAMMABLE) 

Figure 3. Functional Block Diagram 



ADDRESS/DATA OR I/O 
(BYTE PROGRAMMABLE) 
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STANDBY MODE 



The Z86C11's standby modes are: 

■ Stop 

■ Halt 



The Stop instruction stops the internal clock and clock 
oscillation; the Halt instruction stops the internal clock but 
not clock oscillation. 

A reset input releases the standby mode. 



POWER DOWN INSTRUCTIONS 

The Z86C91 has two instructions to reduce power 
cqnsumption during standby operation. HALT turns off the 
processor and UART while the counter/timers and external 
interrupts IRQO, IRQ1, and IRQ2 remain active. 

When an interrupt occurs the processor resumes execution 
after servicing the interrupt. STOP turns off the clock to the 
entire Z86C91 and reduces the standby current to 10 



microamps. The stop mode is terminated by reset, which 

causes the processor to restart the application program at 

address 1 2. 

To complete an instruction prior to entering standby 

mode, use the instructions: 

LD TI^R, #00 

NOP 

STOP or HALT 



PIN DESCRIPTION 

AS. Address Strobe (output, active Low). Address Strobe is 
pulsed once at the beginning of each machine cycle. 
Addresses output via Port 1 for all external program or data 
memory transfers are valid at the trailing edge of AS. Under 
program cpntrol, AS can be placed in the high-impedance 
state along with Ports and 1 , Data Strobe and Read/Write. 

DS. Data Strobe (output, active Low). Data Strobe is 
activated once for each external memory transfer. 

PO^-POy, PI0-PI7, P2o-P27, P3.-P37. I/O Port 
Lines (input/outputs, TTL-compatiblej. Tiiese 32 lines 
are divided into four 8-bit I/O ports that can be 
configured under program control for I/O or external 



memory interface (Figure 3). 



RESET. Reset (input, active Low). RESET initializes the 
Z86C1 1 . When RESET is deactivated, program execution 
begins from internal program location OOOCh- 

R/W. Read/Write (output). R/W is Low when the Z86C1 1 is 
writing to external program or data memory. 

XTALl, XTAL2. Crystal 1, Crystal 2 (time-base 
input and output). These pins connect a parallel- 
resonant crystal (12 MHz maximum) or an external 
single-phase clock (12 MHz maximum) to the on-chip 
clock oscillator and buffer. 



ADDRESS SPACE 



Program Memory. The 16-bit program counter addresses 
64K bytes of program memory space. Program memory 
can be located in two areas: one internal and the other 
external (Figure 4). The first 4096 bytes consist of on-chip 
mask-programmed ROM. At addresses 4096 and greater, 
the Z86C1 1 executes external program memory fetches. 

The first 12 bytes of program memory are reserved for the 
interrupt vectors. These locations contain six 16-bit vectors 
that correspond to the,six available interrupts. 

Data Memory. The Z86C11 can address 60K bytes of 
external data memory beginning at location 4096 (Figure 5). 
External data memory may be included with or separated 
from the external program memory space. DM, an optional 
I/O function that can be programmed to appear on pin P34, 
is used to distinguish between data and program memory 
space. 

Register File. The 256 -byte register file includes four I/O 
port registers (R0-R3), 236 general-purpose registers 
(R4-R 239) and 1 6 control and status registers (R240-R255). 



These registers are assigned the address locations shown in 
Figure 6. 

Z86C11 instructions can access registers directly or 
indirectly with an 8-bit address field. The Z86C11 also 
allows short 4-bit register addressing using the Register 
Pointer (one of the control registers). in the 4-bit 
mode, the register file is divided into 16 working register 
groups, each occupying 16 contiguous locations (Figure 
6). The Register Pointer addresses the starting location 
of the active working- register group (Figure 7). 

Note: Register Bank EO-EF can only be accessed through 
working register and indirect addressing modes. 

Stacks. Either the internal register file or the external data 
memory can be used for the stack. A 16-bit Stack Pointer 
(R254 and R255) is used for the external stack, which can 
reside anywhere in data memory between locations 4096 
and 65535. An 8-bit Stack Pointer (R255) is used for the 
internal stack that resides within the 124 general-purpose 
registers (R4-R1 27). ^ 
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6 


5535 

4096 
4095 

\ 
12 

11 

10 

9 

8 

7 

\6 
5 
4 

^^ 
2 
1 



EXTERNAL 
ROM OR RAM 


UOCATION OF 

FIRST BYTE OF 

INSTRUCTION 

EXECUTED 

AFTER RESET 


ON-CHIP 
ROM 


>< 






IRQS 




IRQ5 




IRQ4 




IRQ4 


INTERRUPT 


IRQS 


VECTOR 
(LOWER BYTE) 


IRQ3 


*. IRQ2 


INTERRUPT 
VECTOR 


If IRQ2 


IRQ1 




IRQ1 




IRQO 




IRQO 



EXTERNAL 

DATA 
MEMORY 



NOT ADDRESSABLE 



Figure 4. Program Memory Map 



Figure 5. Data Memory Map 
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STACK POINTER (BITS 7-C 



STACK POINTER (BITS 15-8) 



REGISTER POINTER 



PROGRAM CONTROL FLAGS 



INTERRUPT MASK REGISTER 



INTERRUPT REQUEST REGISTER 



INTERRUPT PRIORITY REGISTER 



PORTS 0-1 MOD^ 



PORT 2 MODE 



TO PRESCALER 



TIMER/COUNTER 



T1 PRESCALER 



TIMER/COUNTER 1 



TIMER MODE 



GENERAL-PURPOSE 
REGISTERS 



IDENTIFIERS 

SPL 

SPH 

RP 

FLAGS 

IMR 

IRQ 

IPR 

P01M 

P3M 

P2M 

PREO 

TO 



TMR 
SIO 



■^7 re fs ^4 I 
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THE UPPER NIBBLE OF THE REGISTER FILE ADDRESS 
- PROVIDED BY THE REGISTER POINTER SPECIFIES 
THE ACTIVE WORKING-REGISTER GROUP. 



SPECIFIED WORKING- 
REGISTER GROUP 



THE LOWER 
NIBBLE OF 
THE REGISTER 
FILE ADDRESS 
PROVIDED BY 
THE INSTRUCTION 
POINTS TO THE 
SPECIFIED 
REGISTER. 



Figure 6. The Register File 



Figure 7. The Register Pointer 
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SERIAL INPUT/OUTPUT 



Port 3 lines P3o and P3j can be programnned as serial I/O 
lines for full-duplex serial asynchronous receiver/transmitter 
operation. The bit rate is controlled by Counter/Timer 0, with 
a maximum rate of 62. 5K bits/second for 8 MHz. 

The Z86C1 1 automatically adds a start bit and two stop bits 
to transmitted data (Figure 8). Odd parity is also available as 
an option. Eight data bits are always transmitted, regardless 



of parity selection. If parity is enabled, the eighth bit is the 
odd parity bit. An interrupt request (IRQ4) is generated on all 
transmitted characters. 

Received data must have a start bit, eight data bits and at 
least one stop bit. If parity is on, bit 7 of the received data is 
replaced by a parity error flag. Received characters 
generate the IRQ3 interrupt request. 



TRANSMITTED DATA 

(No Parity) 



SP|D7|D6|D5|D4|D3|P;|DiiDo|sT| 
L: 



START BIT 
-EIGHT DATA BITS 
-TWO STOP BITS 



RECEIVED DATA 

(No Parity) 

Sp[D7|d6|d5|D4|P31d2|Pi|Do|st| 

L 



START BIT 
EIGHT DATA BITS 



-ONE STOP BIT 



TRANSMITTED DATA 

(With Parity) 



SPJ p|Dg|D5|D4|D3[D2|D,|Do|ST| 



L, 



St ART BIT 
-SEVEN DATA BITS 
-ODD PARITY 
-TWO STOP BITS 



RECEIVED DATA 

(With Parity) 

SP I P I De I D5 I D4 I D3 I D2 I D, I Dp I St"] 

u 



START BIT 
SEVEN DATA BITS 
PARITY ERROR FLAG 
ONE STOP BIT 



Figure 8. Serial Data Formats 



COUNTER/TIMERS 



The Z86G11 contains two 8-bit programmable counter/ 
timers (Tq and T-i), each driven by its own 6-bit 
programmable prescaler. The Ti prescaler can be driven by 
internal or external clock sources; however, the Tq prescaler 
is driven by the internal clock only 

The 6-bit prescalers can divide the input frequency of the 
clock source by any number from 1 to 64. Each prescaler 
drives its counter, which decrements the value (1 to 256) that 
has been loaded into the counter When the counter reaches 
the end of count, a timer interrupt request— IRQ4 (Tq) or 
• RQ5 (Ti )— is generated . 

The counters can be started, stopped, restarted to continue, 
or restarted from the initial value. The counters can also be 
programmed to stop upon reaching zero (single-pass 
mode) or to automatically reload the initial value and 



continue counting (modulo-n continuous mode). The 
counters, but not the prescalers, can be read any time 
without disturbing their value or count mode. 

The clock source for T^ is user-definable and can be 
the internal microprocessor clock divided by four, or an 
external signal input via Port 3. The Timer Mode 
register configures the external timer input as an 
external clock (1 MHz maximum), a trigger input that 
can be retriggerable or non— retriggerable, or as a gate 
input for the internal clock. The counter/timers can be 
programmably cascaded by connecting the Tq output to 
the input of T^. Port 3 line P3g also serves as a 
timer output (Tqu^) through which T^, T^ or the 
internal clock can be output. 
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I/O PORTS 



The ZSeGl-l has 32 lines dedicated to input and output. 
These lines are grouped into four ports of eight lines each 
and are configurable as input, output or address/data. 
Under software control, the ports can be programmed to 
provide address outputs, timing, status signals, serial I/O, 
and parallel I/O with or without handshake. All ports have 
active pull-ups and pull-downs compatible with TTL loads. 

Port 1 can be programmed as a byte I/O port or as an 
address/data port for interfacing external memory. When 
used as an I/O port, Port 1 may be placed under handshake 
control. In this configuration, Port 3 lines P3 3 and P34 are 
used as the handshake controls RDY-i and DAV-t (Ready 
and Data Available). 

Memory locations greater than 4096 are referenced 
through Port 1 . To interface external memory Port 1 must be 
programmed for the multiplexed Address/Data mode. If 
more than 256 external locations are required. Port must 
output the additional lines. 



Port 1 c_an be placed inthe high-impedance state along with 
Port 0, AS, DS and R/W, allowing the Z86C11 to share 
common resources in multiprocessor and DMA 
applications. Data transfers can be controlled by assigning 
P33 as a Bus Acknowledge input, and P34 as a Bus Request 
output. 



O' 



Z86C11 

MCU 



X HAND SHAKE CONTROLS 
} OAV1 AND RDYi 
> (P33 AND P34) 



. Figure 9a. Port 1 



Port can be programmed as a nibble I/O port, or as an 
address port for interfacing external memory. When used as 
an I/O port. Port may be placed under handshake control. 
In this configuration. P ort 3 lines P32 and P35 are used as 
the handshake controls DAVq and RDYq. Handshake signal 
assignment is dictated by the I/O direction of the upper 
nibble PO4-PO7. 

For external memory references. Port Qcan provide address 
bits As-Ai 1 (lower nibble) or A8-A15 (lower and upper nibble) 
depending on the required address space. If the address 
range requires 12 bits or less, the upper nibble of Port can 
be programmed independently as I/O .while the lower nibble 



is used for addressing. When Port nibbles are defined as 
address bits, they can be set to the high-impedance state 
along with Port 1 and the control signals AS, DS and R/W. 



Z86C11 

MCU 






V HAND SHAKE CONTROLS 
} DAVo AND RDYo 
' (P32 AND PSs) 



Figure 9b. Port 



Port 2 bits can be programmed independently as input or 
output. This port is always available for I/O operations. In 
addition. Port 2 can be configured to provide open-drain 
outputs. 

Like Ports and 1, Port 2 may also be placed under 
handshake control. In this configuration. Port 3 line s P3i 
and P3q are used as the handshake controls lines DAV2 and 
.RDY2. The handshake signal assignment for Port 3 lines P3i 
and P36 is dictated by the direction (input or output) assigned 
to bit 7 of, Port 2. 



zsecii 

MCU 



V HANDSHAKE CONTROLS 
} DAV2 AND RDY2 
' (P3, AND P36) 



Figure 9c. Port 2 



Port 3 lines can be configured as I/O or control lines. In either 
case, the direction of the eight lines is fixed as four input 
(P3o-P33) and four output (P34-P37). For serial I/O, lines P3o 
and P37 are programmed as serial in and serial out 
respectively 

Port 3 can also provide the follow ing control functions: 
handshake for Ports 0, 1 and 2 (DAV and RDY); four external 
interrupt request signals (IRQ0-IRQ3); timer input and output 
signals (Tin and Tqut) and Data Memory Select (DM). 









* 




■* 








"* 


Z86C11 






* 


MCU 


* 







Figure 9d. Port 3 
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INTERRUPTS 

The Z86C1 1 allows six different interrupts from eight sources: 
the four Port 3 lines PSq-PSs, Serial In, Serial Out, and the two 
counter/timers. These interrupts are both maskable and 
prioritized. The Interrupt Mask register globally or individually 
enables or disables the six interrupt requests. When more 
than one interrupt is pending, priorities are resolved by a 
programmable priority encoder that is controlled by the 
Interrupt Priority register 

All Z86C11 interrupts are vectored. When an interrupt 
request is granted, an interrupt machine cycle is entered. This 
disables all subsequent interrupts, saves the Program 



Counter and status flags, and branches to the program 
memory vector location reserved for that interrupt. This 
memory location and the next byte contain the 1 6-bit address 
of the interrupt service routine for that particular interrupt 
request. 

Polled interrupt systems are also supported. To 
accommodate a polled structure, any or all of the interrupt 
inputs can be masked and the Interrupt Request register 
polled to determine which of the interrupt requests needs 
service. 



CLOCK 



The on-chip oscillator has a high-gain, parallel-resonant 
amplifier for connection to a crystal or to any suitable external 
clock source (XTAL1 = Input, XTAL2 = Output). 

The crystal source is connected across XTAL1 and XTAL2, 
using the recommended capacitors (C-i < 15,pf) from each 



pin to ground. The specifications for the crystal are as follows: 

■ AT cut, parallel resonant 

■ Fundamental type, 12 MHz maximum 

■ Series resistance, Rs < 1 00 Q 



INSTRUCTION SET NOTATION 

Addressing Modes. The following notation is used to 
describe the addressing modes and instruction operations 
as shown in the instruction summary. 

IRR Indirect register pair or indirect working-register 

pair address 

Irr Indirect working-register pair only 

X Indexed address 

DA Direct address 

RA Relative address 

IM Immediate 

R Register or working- register address 

r Working-register address only 

IR Indirect- register or indirect working-register 

address / 

Ir Indirect working-register address only 

RR Register pair or working register pair address 

Symbols. The following symbols are used in describing the 
instruction set. 

dst Destination location or contents 

src Source location or contents 

cc Condition code (see list) > 

@ Indirect address prefix 

SP Stack pointer (control registers 254-255) 

PC Program counter 

FLAGS Flag register (control register 252) 

RP Register pointer (control register 253) , 

IMR Interrupt mask register (control register 251) 



Assignment of a value is indicated by the symbol "*-". For 
example, 

dst ^ dst -I- src 

indicates that the source data is added to the destination 
data and the result is stored in the destination location. The 
notation "addr(n)" is used to refer to bit "n" of a given 
location. For example, 

dst (7) 

refers to bit 7 of the destination operand. 

Flags. Control Register R252 contains the following six 
flags: 

C 

z 
s 

V 
D 
H 



Carry flag 
Zero flag 
Sign flag 
Overflow flag 
. Decimal-adjust flag 
Half-carry flag 

Affected flags are indicated by: 

Cleared to zero 

1 Set to one 

* Set or cleared according to operation 

— Unaffected 

X Undefined 
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CONDITION CODES 



Value 



Mnemonic 



Meaning 



Flags Set 



1000 
0111 

1111 

0110 
1110 
1101 
0101 
0100 
1100 
0110 
1110 
1 001 
0001 
1010 
0010 

lll'l 

0111 
1011 
0011 
0000 





Always true 




— 


c 


Carry 




C= 1 


NC 


No carry 




= 


Z 


Zero 




Z= 1 


NZ 


Not zero 




z = o 


PL 


Plus 




s = o 


Ml 


Minus 




S=1 


OV 


Overflow 




V= 1 


NOV 


No overflow 




V = 


EQ 


Equal 




Z= 1 


NE 


Not equal 




z = o 


GE 


Greater than or equal 




, (SXORV) = 


LT 


Less than 




(SXORV)= 1 


GT 


Greater than 




[ZOR(SXORV)] = 


LE 


Less than or equal 




[ZOR(SXORV)] = 1 


UGE 


Unsigned greater than or 


equal 


= 


ULT 


Unsigned less than 




0= 1 


UGT 


Unsigned greater than 




(0 = OANDZ = 0) = 1 


ULE 


Unsigned less than or equal 


(OORZ) = 1 




Never true 




_ 



INSTRUCTION FORMATS 



COF, Dl, El, IRET, NOP, 
RCF, RET, SCF 



One-Byte Instructions 



CLR, GPL, DA, DEC, 



6n ll 1 1 oldst/src I DECW, INC, INCW, POP, 
0« |1 1 1 0|dst/src I pu5„ p, RLC. RR. 



OR |l 1 1 o| dst I 



OPC 


MODE 


dst 


src 



MODE 


OPC 


dst/src 


src/dst 



PUSH, RL, RLC, RR, 
RRC, SRA, SWAP 

JP, CALL (Indirect) 



ADC, ADD, AND, 
CP, OR, SBC, SUB, 
TCM, TM, XOR 



LD, LDE,LDEI, 
LDC, LDCI 



OPC MODE 



1110 


src 


1110 


dst 



ADC, ADD, AND, CP, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 



ADC, ADD, AND, CP, 
LD, OR, SBC, SU 
TCM, TM, XOR 



MODE I OPC 



1110 


src 


1110 


dst 



MODE 


OPC 


dst/src 


X 


ADDRESS 1 



dst/src I OPc" 



dst/CC I OPc" 



OR |l 1 1 Ol src I 



DAl 



6Fh [ 7Fh 



Two-Byte Instructions 



Three-Byte Instructions 
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INSTRUCTION SUMMARY 



Instruction 
and Operation 


AddrlVlode 
dst src 


Opcode 
Byte 
(Hex) 


Flags Affected 
C Z S V D H 


ADC dst.src 

dst *- dst + src + C 


(Note1) 


1D 


* * * * * 


ADD dst.src 
dst *- dst + src 


(Note1) 


on 


* * * * * 


AND dst.src 
dst*- dst AND src 


(Note1) 


SD 


- * * 


CALL dst 

SP^SP - 2 
@SP^PC;PC*-dst 


DA 
IRR 


D6 
D4 


l_ 


CCF 

C-NOTC 




EF 


* 


CLR dst 

dst*-0 


R 
IR 


BO 
B1 




COIVI dst 

dst -NOT dst 


R 
IR 


60 
61 


- * * 


CP dst.src 
dst - src 


(Note1) 


AD 


* * * * 


DA dst 

dst -DA dst 


R 
IR 


40 
41 


* * * X 


DEC dst 
dst-dst- 1 


R 
IR 


00 
01 


— * * * 


DECWdst 

dst-dst- 1 


RR 
IR 


80 
81 


— * * * 



IMR(7)-0 


8F 


DJNZ r.dst RA 


rA 


r-r- 1 


r = 0-F 


ifr^O 




PC - PC + dst 




Range: +127,-128 




El 


9F 



IMR (7) - 1 



HALT 



7F 



INC dst 


r 


rE 


- * * * 


dst-dst+ 1 




r = 0- F 






R 


20 






IR 


21 





INCW dst 

dst - dst + 1 



RR 
IR 



AO — * * * 

A1 



IRET 

FLAGS - @SP; SP - 
PC-@SP;SP-SP 



BF ****** 



Instruction 
and Operation 


AddrMode Opcode Flags Affected 


Byte 
dst src (Hex) C Z S V D H 


JP cc.dst 
if cc is true 
PC*- dst 


DA CD 

c = 0-F 
IRR 30 



SP + 1 
+ 2; IMR (7) 



*-1 



JRcc.dst RA cB 
if cc is true, c = - F 

PC *- PC + dst 
Range: +127, -128 

LD dst.src r Im rC 

dst ^ src r R r8 

R r r9 

r=,0- F 

r X C7 

X r D7 

r Ir E3 

Ir r F3 

R R E4 

R IR E5 

R IM E6' 

IR IM E7 

IR ' R F5 

r Irr C2 

Irr r D2 

Ir Irr C3 

Irr Ir D3 

r Irr 82 

Irr r 92 

Ir Irr 83 

Irr Ir 93 

ff" 

(Notel) 4n 

R 50 

IR 51 

R 70 

src IR 71 

cf" 

AF 
f 2 

RLdst r— — jl 90" **** 



LDC dst.src . 
dst *- src 


r 
Irr 


Irr 
r 


C2 
D2 








— 


LDCI dst.src 

dst ^ src 

r -*- r + 1 ; rr *- rr + 1 


Ir 
Irr 


Irr 
Ir 


C3 
D3 


"" 


__. 


"" 


LDE dst.src 
dst <- src 


r 
Irr 


Irr 

r 


82 
92 





— 


— 


LDEI dst.src 

dst *- src 

r *- r + 1 ; rr *- rr + 1 


Ir 
Irr 


Irr 
Ir 


83 
93 


"" 


___ 


"" 


NOP 






FF 








-- 


OR dst.src 

dst ^ dst OR src 


(Notel) 


4n 


— * 


* - 


— 


POP dst 

dst *- @SP; 
SP^SP + 1 


R 
IR 




50 
51 








PUSH src 

SP*-SP- 1;@SP*- 


•src 


R 
IR 


70 
71 








— 


RCF 

C^O 






CF 


- 


^_ 


— 


RET 

PC^@SP;SP-SP 


+ 2 




AF 








— 
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INSTRUCTION SUMMARY (Continued) 



Instruction 
and Operation 


AddriMode 


Opcode 
Byte 
(Hex) 


Rags Affected 


dst 


src 


C Z S V D H 


Dl O rAe-* 


p 




10 
11 






3-^IR 




McH' 




■l«V« 1 . 


_ 




EO 
El 




RR dsl 1 1 


a^iR 


* * * * 


L|c|L|. 








••.•.^ 






CO 
C1 




RRC dsl 1 


3^IR 


* * * * 


SBC dst.src 

dst ^ dst *- src -*- C 


(Note1) 


SD 


* * * * 1 * 


SCF 

C-1 






DF 


1 








DO 
D1 




-HAOStLf^ 


-•^IR 


* * * 


1 ♦ ♦ 




SRP src 

RP *- src 




Im 


31 




STOP 






6F 




SUBdst.src ^ 
dst *- dst ^ src 


(Note 1) 


2n 


* * * * 1 * 


SWAP H«t ♦ 


ID 




FO 
F1, 


X * * X 


1 


j-^IR 




TCIVI dst.src 
(NOT dst) AND src 


(Note 1) 


en 


- * * 



Instruction 
and Operation 


AddrMode 


Opcode 
Byte 
(Hex) 


Flags Affected 


dst src 


Z S V D H 


TM dst.src 
dst AND src 


(Notel) 


TO 


- * * - - 


XOR dst.src 
dst*- dst XOR src 


(Notel) 


BD 


- * * 



NOTE: These instructions have an identical set of addressing modes, 

which are encoded for brevity. The first opcode nibble is found in 
the instruction set table above. The second nibble is expressed 
symbolically by a D in this table, and its value is found in the 
following table to the left of the applicable addressing mode pair 

For example, the opcode of an ADC instruction using the 
addressing modes r (destination) and Ir (source) is 13. 



Addr Mode 



dst 


src 


r 
r 


r 
Ir 


R 


R 


R 


IR 


R 


IM 


IR 


IM 



Lower 
Opcode Nibble 





H 
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REGISTERS 



R240SIO 
SERIAL I/O REGISTER 

(FOh; Read/Write) 

|P7|De|D5|D«|D3|D2|DjDo| 



R244 TO 
COUNTER/TIMER REGISTER 

(F4h; Read/Write) 

|D,|0.|D5|D«|D3|D2|DrrDn 



- SERIAL DATA (Og = LSB) 



To CURRENT VALUE (WHEN READ) 



R241 TMR 
TIMER MODE REGISTER 

(F1h; Read/Write) 



E 



Tout MODES 

NOT USED = 00 

To OUT = 01 - 

T, OUT = 10 

INTERNAL CLOCK OUT = 11 

T,N MOOES 
EXTERNAL CLOCK INPUT = 00 
GATE INPUT = 01 
TRIGGER INPUT = 10 - 
(NONRETRIGGERABLE) 

TRIGGER INPUT = 11 
(RETRIGGERABLE) 



Pel Pi 



D« I Da ( D; I Di (d7| 



R245 PREO 
PRESQALERO REGISTER 

(F5h; Write Only) 



{EM 



NO FUNCTION 
LOAD To 

= DISABLE To COUNT 

1 = ENABLE To COUNT 

= NO FUNCTION 

1 = LOADT, 



P4|P3|D2|PlfDn 



1 = To MODULON 



PRESCALER MODULO 
-(RANGE: 1-64 DECIMAL 
01-00 HEX) 



R242 T1 
COUNTER TIMER 1 REGISTER 

(F2h; Read/Write) 



D, D, Ds D4 Ds Dj 



Ha 



R246 P2M 
PORT 2 MODE REGISTER 

(F6h; Write Only) 

|D,|Dg|D5|D4|D3|D;|D,|Dn 



T, CURRENT VALUE (WHEN READ) 



P2o-P27 I/O DEFINITION 
- DEFINES BIT AS OUTPUT 
1 DEFINES BIT AS INPUT 



R243 PRE1 
PRESCALER 1 REGISTER 

(F3h; Write Only) 



R247 P3M 
PORT 3 MODE REGISTER 

(F7h; Write Only) 



P«|D3|D2|Pi|Dri 



I Dr I Dg I D5 I D4 



L COUNT MODE 
= Ti SINGLE-PASS 
1 = T, MODULON 

CLOCK SOURCE 

1 = T, INTERNAL 

= Ti EXTERNAL TIMING INPUT 
(T,n) MODE 

PRESCALER MODULO 

(RANGE: 1-64 DECIMAL 

01-00 HEX) 



'|P2|Pi|Do| 



u 



= INPUT P34 = OUTPUT 

= INPUT P34 = m 

= DAV1/RDY1 P34 = RDY1/DAV1 
= INPUT (T,n) P36 = OUTPUTJTou 
= DAV2/RDY2 P36 = RDY2/DAV2 



Figure 1 1 . Control Registers 
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REGISTERS (Continued) 



R248P01M 
PORT AND 1 MODE REGISTER 

(F8h; Write Only) 



PO4-PO7 MODE 
OUTPUT = - 
INPUT a 

EXTERNAL MEMORY TIMING 
NORMAL := 
EXTENDED = 1 



|d7|d,|d5|d4 


D3|D,|D,|D„| 



PO0-PO3 MODE 
00 = OUTPUT 
■ 01 = INPUT 
IX « A,-Aii 

STACK SELECTION 

:« EXTERNAL 

1 s INTERNAL 

PI0-PI7 MODE 

00 = BYTE OUTPUT 

01 = BYTE INPUT 

10 » AO0-AD7 

11 » HjQmMPEDANCE AO0-AD7, 

AS, DS, RAV, As-All, Ai2-Ai5 
IF SELECTED 



R252 FLAGS 
FLAG REGISTER 

(FCh; Read/Write) 

|D7|D,[D5|D«|^3|D2|DtiDo1 



li: 



USER FLAG F1 

USER FLAG F2^ 
-HALF CARRY FLAG 
-DECIMAL ADJUST FLAG 
-bvERFLOW FLAG 
-SIGN FLAG 
-ZERO FLAG 



R249 IPR 
INTERRUPT PRIORITY REGISTER 

(F9h; Write Only) 




|D;|D,|DsfD, 


D3I02ID, |Do| 




RESERVED » 

IRQ3, IRQS PRIORITY (GROUP A) 










INTERRUPT GROUP PRIORITY 
RESERVED = 000 
C > A > B = 001 


REGISTER 


1 = IRQS > IRQS 
IRQO, IRQ2 PRIORITY (GROUP B) 








A > C> B = Oil 
B > C > A = 100 
C > B > A = 101 
B > A > C = 110 
RESERVED =111 




1 = IRQO > IR62 
IRQ1, IRQ4 PRIORITY (GROUP C) 






1 = iRQ4 > IRQ1 













R253 RP 
REGISTER POINTER 

(FDh; Read/Write) 

iD,|D,|Ds|D4|D3|Da|D,|D,| 



1^ 



R250IRQ 
INTERRUPT REQUEST REGISTER 

(FAh; Read/Write) 

[D7rP6|D5lD4|D3|D2lPi|Po| 
lESERVED 1 « 



R254SPH 
STACK POINTER 

(FEh; Read/Write) 

|Dr|Dg|D5|D4lD3|D;|D^|Do| 



STACK POINTER UPPER 



iRQ2 « P3i INPUT 
IRQS » P3o INPUT, SERIAL INPUT 
IRQ4 s To, SERIAL OUTPUT 
IRQS = Ti 



R251 IMR 
INTERRUPT MASK REGISTER 

(FBh; Read/Write) 



|D7|D8|D5|D4|D3|D;|D,|Po| 



R255SPL 
STACK POINTER 

(FFh; Read/Write) 

|D7|Dg|D5|D4|D3|D;|D, [DqI 



1 ENABLES IRQO-IRQS 
" (Do = IRQO) 



STACK POINTER LOWER 
" BYTE (SP0-SP7) 



-I ENAB(.ES INTERRUPTS 



Figure 1 1 . Control Registers (Continued) 
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OPCODE MAP 



Lower Nibble (Hex) 
7 8 9 






6,5 


6.5 


6,5 


6,5 


. 10.5 


10.5 


10,5 


10,5 


6,5 


6.5 


12/10,5 


12/10.0 


6,5 


12/10,0 


65 




DEC 


DEC 


ADD 


ADD 


ADD 


ADD 


ADD 


ADD 


LD 


LD 


DJNZ 


JR 


LD 


JP 


INC 




Ri 


iRi 


ri.r2 


ri.lr2 


R2.R1 


IR2,Ri 


Rl,IM 


IRl,IM 


I-1.R2 


r2.Ri 


ri.RA 


cc.RA 


ri.lM 


ccDA 


ri 




6.5 


6,5 


6,5 


6.5 


10.5 


10,5 


10.5 


10,5 
































RLC 


RLC 


ADC 


ADC 


ADC 


ADC 


ADC 


ADC 
































Ri 


iRi 


ri,r2 


'■l.lr2 


R2.R1 


IR2,Ri 


R1.IM 


IR1.IM 
































6,5 


6,5 


6,5 


6.5 


10,5 


10,5 


10.5 


10,5 




INC 


INC 


SUB 


SUB 


SUB 


SUB 


SUB 


SUB 
































Ri 


IRi 


ri,r2 


ri.lr2 


R2.R1 


IR2.R1 


R1.IM 


IR1.IM 
































8,0 


6,1 


6.5 


6,5 


10,5 


10,5 


10.5 


10,5 




JP 


SRP 


SBC 


SBC 


SBC 


SBC 


SBC 


SBC 
































IRRi 


IM 


n.r2 


ri.lr2 


R2.R1 


IR2.R1 


R1.IM 


IR1.IM 
































8,5 


8,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10.5 




DA 


DA 


OR 


OR 


OR 


OR 


OR 


OR 
































Ri 


IRi 


ri,r2 


ri.lr2 


R2.R1 


IR2,Ri 


R1.IM 


If^l.lM 
































10,5 , 


10.5 


6.5 


6,5 


10,5 


10,5 


10,5 


10.5 




POP 


POP 


AND 


AND 


AND 


AND 


AND 


AND 
































Ri 


iRi 


ri.r2 


f^M2 


R2.R1 


IR2.R1 


Rl.lM 


IRl,IM 
































6,5 


6,5 


6.5 


6.5 


10.5 


10,5 


10,5 


10,5 


6.0 


COM 


COM 


TCM 


TCM 


TCM 


TCM 


TCM 


TCM 






























STOP 


Ri 


IRi 


ri.r2 


ri.lr2 


R2.R1 


IR2,Ri 


Rl,IM 


IRl,IM 
































10/12,1 


12/14,1 


6.5 


6,5 


10.5 


10.5 


10.5 


10.5 


7.0 


PUSH 


PUSH 


TM 


TM 


TM 


TM 


TM 


TM 






























HALT 


R2 


IR2 


ri.r2 


'■l.li'2 


R2.R1 


IR2,Ri 


Rl.lM 


IR1.IM 










- 






















10.5 


10.5 


12.0 


18,0 










6.1 


DECW 


DECW 


LDE 


LDEI 






































Dl 


RR-| 


IRi 


ri.lrr2 


Iri,lrr2 








































6,5 


6.5 


12.0 


18.0 










6.1 


RL 


RL 


LDE 


LDEI 






































El 


Ri 


IRi 


r2,lrri 


Ir2.lrri 








































10,5 


10.5 


6,5 


6,5 


10,5 


10,5 


10.5 


10.5 


14.0 


INCW 


INCW 


CP 


CP 


CP 


CP 


CP 


CP 






























RET 


RRl 


IRi 


ri.r2 


ri,lr2 


R2.R1 


IR2,Ri 


Rl.lM, 


IR1.IM 
































6,5 


6.5 


6,5 


"6,5 


10,5 


10.5 


10.5 


10.5 - 


16.0 


CLR 


CLR 


XOR 


XOR 


XOR 


XOR 


XOR 


XOR 






























IRET 


Ri 


IRi 


ri.r2 


'■l.l''2 


R2.R1 


IR2.R1 


R1.IM 


IRl.lM 
































6,5 


6.5 


12,0 


18.0 








10.5 


6,5 


RRC 


RRC 


LDC 


LDCI 








LD 






























RCF 


Ri 


IR1 


ri.lrrs 


Iri.lrrg 








ri.x.R2 
































6,5 


6,5 


12,0 


18.0 


20.0 




20.0 


10.5 


6.5 


SRA 


SRA 


LDC 


LDCI 


CALL* 




CALL 


LD 






























SCF 


Ri 


IRi 


r2,lrri 


Ir2,lrri 


IRR1 




DA 


r2.x.Ri 
































6,5 


6.5 




6.5 


10.5 


10,5 


10,5 


10,5 


6.5 


RR 


RR 




LD 


LD 


LD 


LD 


LD 






























CCF 


Ri 


IRi 




ri,IR2 


R2.R1 


IR2,Ri 


R1.IM 


IRl,IM 
































8,5 


8.5 




6.5 




10.5 






6.0 


SWAP 


SWAP 




LD 




LD 


































NOP 


Ri 


IRi 




1^/2 




R2.IR1 






1 


r 


\ 


' 


1 


r 


' 


r 


\ 


' 


\ 


f 


\ 


r 





LOWER 
OPCODE 



Bytes per Instruction 



EXECUTION 
CYCLES- 



V^ 



FIRST, 
OPERAND 



AX, 



SECOND 
OPERAND 



Legend: 

R = 8-bit address 
r = 4-bit address 
Rl or ri = Dst address 
R2 or r2 = Src address 

Sequence: 

Opcode, First Operand, Second Operand 

NOTE: The blank areas are not defined. 



*2-byte instruction, fetch cycle appears as a 3-byte instruction 
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ABSOLUTE MAXIMUM RATINGS 

Voltages on all pins with respect 

toGND -0.3V to +7.0V 

Operating Ambient 

Temperature .~ .See Ordering Information 

Storage Temperature ~65°Cto + 150°C 

STANDARD TEST CONDITIONS 

The DC characteristics listed below apply for the following 
standard test conditions, unless otherwise noted. All 
voltages are referenced to GND. Positive current flows into 
the referenced pin. 

Standard conditions are as follows: 

■ +4.5 ^ Vcc ^ + 5.5V 

■ GND = OV 

■ C < T;^ < +70^ C for S (Standard temperature) 

■ -40 C < T;^ <+100 C for E (Extended temperature) 

DC CHARACTERISTICS 



Stresses-greater than those listed under Absolute Maximum Ratings may 
cause permanent damage to the device. This is a stress rating only; 
operation of the device at any condition above those indicated in the 
operational sections of these specifications is not implied. Exposure to 
absolute maximum rating conditions for extended periods may affect 
device reliability 



FROM OUTPUT , 
UNDER TEST ^ 



150pF?fc 



Figure 12. Test Load 1 




Symbol 


Parameter 


Min Typ 


IVIax 


Unit 


Condition 


VCH 


Clock Input High Voltage 


3.8 


Vcc 


V 


Driven by External Clock Generator 


VCL 


Clock Input Low Voltage 


-0.3 


0.8 


V 


Driven by External Clock Generator 


V|H 


Input High Voltage 


2.0 


Vcc 


V 




V|L 


Input Low Voltage 


-0.3 


0.8 


V 




Vrh 


Reset Input High Voltage 


3.8 - 


Vcc 


V 




Vrl 


Reset Input Low Voltage 


-0.3 


0.8 


V 




VOH 


Output High Voltage 


2.4 




V 


lOH = -250mA 


VOH 


Output High Voltage 


Vcc -lOOmV 




V 


lOH = -lOOnA 


Vol 


Output Low Voltage 




0.4 


V 


Iql = +2.0 nnA 


l|L 


Input Leakage 


-10 


10 


mA 


OV<V|N< + 5.25V 


lOL 


Output Leakage 


-10 


10 


hA 


OV<V|N< + 5.25V 


l|R 


Reset Input Current 




-50 


mA 


Vcc= +5.25VVrl = 0V 


Ice 


Supply Current 




30 


mA 


All outputs and I/O pins floating , 12 MHz 


IpC-i 


Standby Current 


5 




nnA 


Halt Mode 


ICC2 


Standby Current 




10 


mA 


Stop Mode 



\qqZ requires loading TMR (%F1) with any value prior to STOP execution. 

Use the sequence: 

LD TMR, #00 

NOP 

STOP 
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-•<12>^ 



PORTO, 
DM 



y. 



h<T>- 



^=^ 



DS 

(READ) 



DS 

(WRITE) 



X 



-•-©-^ 



-<i>- 



^: 



■<D- 



-®- 



3C 



N: 



-<2>- 



f 



3: 



-*<«>*► 



K 



y 



Figure 13. External I/O or Memory Read/Write 



AC CHARACTERISTICS 

External I/O or Memory Read and Write Tinning 









12 MHz 


16 MHz 




Number 


Symbol 


Parameter 


Min 


Max 


MIn 


Max 


Notes*f 


1 


TdA(AS) 


Address Valid to AS t Delay 


35 




20 




2.3 


2 


TdAS(A) 


AS t to Address Float Delay 


45 




30 




2,3 


3 


TdAS{DR) 


AS t to Read Data Required Valid 




220 




180 


1.2.3 


4 


TwAS 


AS Low Width 


55 




35 




2.3 


5 


TdAz(DS) 


Address Float to DSi 


0, 











6 


TwDSR 


D5 (Read) Low Width 


185 
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1.2.3 


7 


TwDSW 


DS (Write) Low Width 


110 




80 




1,2.3 


8 


TdDSR(DR) 


D§ 4 to Read Data Required Valid 
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75 


1.2.3 


9 


ThDR(DS) 


Read Data to DS t Hold Time 














10 


TdDS(A) 


DS t to Address Active Delay 


45 




20 




2,3 


11 


TdDS(AS) 


MttoASI Delay 


55 




20 




2,3 


12 


TdR/W(AS) 


R/W Valid to AS 1 Delay 


30 




20 




2.3 


13 


TdDS(R/W) 


DSttoR/WNot.Valid 


35 




20 




2.3 


14 


TdDW(DSW) 


Write Data Valid to DS (Write) i Delay 


35 




25 




2.3 


15 


TdDS(DW) 


D§ t to Write Data Not Valid Delay 


35 




20 




2,3 


16 


TdA(DR) 


Address Valid to Read Data Required Valic 




255 




200 


1,2.3 


17 


TdAS(DS) 


ASttoD^iDelay 


55 




40 




2,3 



NOTES: 

1 . When using extended nnemory timing add 2 TpC. 

2. Timing numbers given are for minimum TpC. 

3. See clocl< cycle time dependent characteristics table. 



* All units in nanoseconds (ns). 
t Test Load 1 

* All timing references use 2.0V for a logic "1 " and 0.8V for a logic, "0" 
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-<i> 



-^D-^\ 



\ /^-\ 



IRON 



' ^ — : — ® 
V<i>-4^ — ® — ^ 






Figure 14. Additional Timing 






AC CHARACTERISTICS 

Additional Timing Table 


Number Symbol Parameter 


12 MHz 
MIn Max 


16 MHz 
Min Max 


Notes* 



1 


TpC 


2 


TrCTfC 


3 


TwC 


4 


TwTinL 


5 


TwTinH 


6 


TpTin 


7 


TrTln.TfTin 


8A 


TwIL 


8B 


TwIL 


9 


TwIH 



Input Clock Period 83 
Clock Input Rise and Fall Times 

Input Clock Width 70 

Timer Input Low Width 70 

Timer Input High Width 3TpC 



1000 


62.5 


1000 


1 


15 




10 


1 




21 




1 




50 




2 




3TpC 




2 




8TpC 




2 


100 




100 


2 




50 




2,4 




3TpC 




2.5 




3TpC 




2.3 



Timer Input Period 8TpC 
Timer Input Rise and Fall Times 

Interrupt Request Input Low Time 70 

Interrupt Request Input Low Time 3TpC 

Interrupt Request Input High Time 3TpC 



NOTES: 

1 . Clock timing references use 3.8V for a logic "1 " and 0.8V for a logic "0". 

2. Timing references use 2.0V for a logic "1 " and 0.8V for a logic "0". 

3. Interrupt request via Port 3. 

4. Interrupt request via Port 3 (P3i •P33). 

5. Interrupt request via Port 3 (P3o). 
* Units in nanoseconds (ns). 



^ 



DATA IN VALID - 



(i> 



\ 



-0- 
-<3>- 



V 



X 



-&- 



r 



Figure 15a. Input Handshake 



DAV 

(OUTPUT) 



DATA OUT VALID 



\ 



-©- 



1 



<D 



-<z>- 



r 



Figure 15b. Output Handshake 
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AC CHARACTERISTICS 

Handshake Timing 



Number Symbol 



Parameter 



12MHz, 16MHz 
Min Max 



Notest* 



1 


T^DKDAV) 


Data In Setup Time 





2 


ThDI(DAV) 


Data In Hold Time 


145 


3 


TwDAV 


Data Available Width 


110 


4 


TdDAVIf(RDY) 


DAVIInput to RDYI Delay 


20 


5 


TdDAVOf(RDY) 


DWI Output to RDYi Delay 





6 


TdDAVIr(RDY) 


DAVt Input to RDYt Delay 




7 


TdDAVOr(RDY) 


DAV t Output to RDY t Delay 





8 


TdDO(DAV) 


Data Out to DWI Delay 


Tpc 


9 


TdRDY(DAV) 


RDY i Input to DWt Delay 






115 



1.2 
1,3 



115 



130 



1.2 
1.3 
1 

1 



NOTES: 

1 . Test load 1 

2. Input handshake 

3. Output handshake 

t All tinning references use 2.0V for a logic "1 " and 0.8V for a logic "0". 
* Units in nanoseconds (ns). 
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ADyANCED INFORMATION 
Product Specification 



Z86C21/Z86E21 CMOS 

CMOS Z8® 8K ROM MCU 



June 1987 



FEATURES 



Complete microcomputer, 8K bytes of ROM, 256 bytes of 
RAM, 32 I/O lines, and up to 56K bytes addressable 
external space each for program and data memory. 

256-byte register file, including 236 general-purpose 
registers, 4 I/O port registers, and 16 status and 
control registers. 

Minimum instruction execution time of 0.6 jus, 
average of 1.0 pis. 

Vectored, priority interrupts for I/O, counter/timers, and 
UART. 

Full-duplex UART and two programmable 8-bit counter/ 
timers, each with a 6-bit programmable prescaler 



■ Register Pointer so that short, fast instructions can 
access any of 16 working-register groups in .6 (jls. 

■ On-chip oscillator which accepts crystal or external clock 
drive. 

■ Standby modes— Halt and Stop 

■ Single -i- 5V power supply— all pins TTL-compatible. 

■ 12and16[VIHz. 

■ CMOS process 

■ Z86E21 compatible field— programmable version — 
same feature set. 



GENERAL DESCRIPTION 

The Z86C21 microcomputer (Figures 1 and 2) 
introduces a new level of sophistication to single- 
chip architecture. Compared to earlier single-chip 
microcomputers, the Z86C21 offers faster execution; 



more efficient use of memory; more sophisticated 
interrupt, input/output and bit-manipulation 
capabilities; and easier system expansion. 



TIMING 




AND 
CONTROL 


^ 










PORTO 




(NIBBLE] 
PROGRAMMABLE) 

I/O OR As-Ais 












PORT 1 




(BYTE 
PROGRAMMABLE) 




i/0 OR AD0-AD7 









RESET + 5 V 

R/W GND 

DS XTAL1 

AS XTAL2 

POo P2o 

PO1 P2i 

PO2 P22 

PO3 P23 

P04 Z86C21 f'^* 
P05 Z86E21P25 

pOg MCU P26 

PO7 P27 



PI1 
PI2 
PI3 
PI4 
PI5 
Pie 



P3o 
P3i 

P32 
P33 
P34 
P35 
P36 
P37 



PORT 2 

(BIT PRO- 
GRAMMABLE) 



PORT 3 

SERIAL AND 
PARALLEL I/O 
AND CONTROL 









Ky 






+ 5V 


L 


1 




40 


J 


XTAL2 


L 


2 




39 


J 


XTAL1 


L 


3 




38 


1 


P37 


C 


4 




37 


1 


P3o 


C 


5 




36 


1 


RESET 


L 


6 




35 


2 


R/W 


L 


7 




34 


1 


DS 


L 


8 




33 


1 


AS 


C 


9 


Z86C21 


32 


J 


P35 


L 


10 


Z86E21 


31 


1 


GND 


C 


11 


MCU 


30 


1 


P32 


C 


12 




29 


1 


POo 


C 


13 




28 


1 


PO1 


L 


14 




27 


1 


PO2 


C 


15 




26 


1 


PO3 


L 


16 




25 


1 


PO4 


L 


17 




24 


1 


PO5 


C 


18 




23 


1 


POe 


C 


19 




22 


1 


PO7 


c 


20 




21 


J 



P36 

P3i 

P27 
P26 
P25 

P24 



P2o 

P33 
P34 



^ ifff^ifi^^^^^ <}'!>*' <j'b"'<j'V'^<j'v*',a?' 





'' 6 


5 4 3 2 1 44 43 42 41 40 X 




RFT 


7 
8 




39 
38 


NC 


R/V? 




P24 


DS 
A5 


9 
10 


Z86C21 


37 
36 


P23 
P22 


P35 
GND 
P32 


11 
12 
13 


Z86E21 

MCU 


35 
34 
33 


P2i 
P20 
P33 


POo 


14 




32 


P34 


PO1 


15 




31 


Pl7 


PO2 


16 
17 




30 
29 


Pl6 


NC 




P15 




^ 


19 20 21 22 23 24 25 26 27 i 


1/ 





Figure 2b. 44-pin Chip Carrier, 
Pin Assignments . 



Figure 1 . Pin Functions 



Figure 
Package 



2. 40-pin Dual-ln-Line 
(DIP), Pin Assignments 
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General Purpose Microcontroller 

Under program control, the Z86C21 can be tailored 
to the needs of its user. It can be configured as a 
stand-alone microcomputer with 8K bytes of 
internal ROM, a traditional microprocessor that 
manages up to 112K bytes of external memory, or 



a parallel— processing element in a system with other 
processors and peripheral controllers linked by the 
Z— BUS bus. In all configurations, a large number 
of pins remain available for I/O. 



Field Programmable Version 

The Z86E21 is a pin compatible Onetime 
Programmable version of the Z86C21. The Z86E21 
contains 8K bytes of EPROM memory in place of the 
:8K bytes of masked ROM on the Z86C21. The 



Z86E21 also contains a programmable memory 
protect feature to provide program security by 
disabling all external accesses to the internal EPROM 
array. 



ARCHITECTURE 



Z86C21 architecture is characterized by a flexible I/O 
scheme, an efficient register and address space structure 
and a number of ancillary features that are helpful in many 
applications. 

Microcomputer applications demand powerful I/O 
capabilities. The Z86C21 fulfills this with 32 pins dedicated 
to input and output. These lines are grouped into four ports 
of eight lines each and are configurable under software 
control to provide timing, status signals, serial or parallel I/O 
with or without handshake, and an address/data bus for 
interfacing external memory 

Because the multiplexed address/data bus is merged with 
the l/0-oriented ports, the Z86C21 can assume many 
different memory and I/O configurations. These config- 
urations range from a self-contained microcomputer to a 



microprocessor that can address 120K bytes of external 
memory (Figure 3). 

Three basic address spaces are available to support this 
wide range of configurations: program memory (internal 
and external), data memory (external) and the register 
file (internal). The 256-byte random-access register 
file is composed of 236 general— purpose registers, 4 I/O 
port registers, and 16 control and status registers. 

To unburden the program from coping with real-time 
problems such as serial data communication and 
counting/timing, an asynchronous receiver/transmitter 
(UART) and two counter/timers with a large number of . 
user-selectable modes are offered on-chip. Hardware 
support for the UART is minimized because one of the 
on-chip timers supplies the bit rate. 



OUTPUT INPUT 



COUNTER/ 

TIMERS 

(2) 



INTERRUPT 
CONTROL 



R 






mm 



(BIT PROGRAMMABLE) 



i 1 



iE 



REGISTER 
POINTER 



REGISTER FILE 
256 X 8-BIT 






^ 



XTAL AS DS R/W RESET 

ti f t t i 



MACHINE TIMING AND 
INSTRUCTION CONTROL 



J 



H 



PROGRAM 

MEMORY 

8192 X 8-BIT 



IT 



PROGRAM 
COUNTER 



3T 



M 






ADDRESS OR I/O 
(NIBBLE PROGRAMMABLE) 



ADDRESS/DATA OR I/O 
(BYTE PROGRAMMABLE) 



Figure 3. Functional Block Diagram 
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STANDBY MODE 



The Z86C21's standby modes are: 

■ Stop 

■ Halt 

The Stop instruction stops the internal clock and clock 
oscillation; the Halt instruction stops the internal clock but 
not clock oscillation. 



A reset input releases the standby mode. 

To complete an instruction prior to entering standby mode, 
use the instructions: 

NOP(FFh) + ST0P(6Fh) 
NOP(FFh) + HALT(7Fh) 



PIN DESCRIPTION 



AS. Address Strobe (output, active Low). Address Strobe i$ 
pulsed once at the beginning of each machine cycle. 
Addresses output via Port 1 for all external program or data 
memory transfers are valid at the trailing edge of AS. Under 
program control, AS can be placed in the high-impedance 
state along with Ports and 1 , Data Strobe and Read/Write. 

DS. Data Strobe (output, active Low). Data Strobe is 
activated once for each external memory transfer 

PO0-PO7, P1o-Pl7, P2o-P27, P3o-P37. I/O Port Lines 
(input/outputs, TTL-compatible). These 32 lines are divided 
into four 8-bit I/O ports that can be configured under 
program control for I/O or external memory interface (Figure 3). 



RESET. Reset (input, active Low). RESET initializes the 
Z86C21 . When RESET is deactivated, program execution 
begins from internal program location OOOCh- 

R/W. Read/Write (output). R/W is Low when the Z86C21 is 
writing to external program or data memory 

XTALl, XTAL2. Crystal 1, Crystal 2 (time-base input 
and output). These pins connect a parallel— resonant 
crystal (12 or 20 MHz maximum) or an external single- 
phase clock (12 or 20 MHz maximum) to the on-chip 
clock oscillator and buffer. 



ADDRESS SPACE 



Program Memory. The 16-bit program counter addresses 
64K bytes of program memory space. Program memory 
can be located in two areas: one internal and the other 
external (Figure 4). The first 8192 bytes consist of on-chip 
mask-programmed ROM. At addresses 8192 and greater, 
the Z86C21 executes external program memory fetches. 

The first 12 bytes of program memory are reserved for the 
interrupt vectors. These locations contain six 16-bit vectors 
that correspond to the six available interrupts. 

Data Memory. The Z86C21 can address 56K bytes of 
external data memory beginning at location 4096 (Figure 5). 
External data memory may be included with or separated 
from the external program memory space. DM, an optional 
I/O function that can be programmed to appear on pin P34, 
is used to distinguish between data and program memory 
space. 

Register File. The 256-byte register file includes 4 
I/O port registers (R0-R3), 236 general-purpose 
registers (R4-R239) and 16 control and status registers 
(R240-R255). 



These registers are assigned the address locations shown in 
Figure 6. 

Z86C21 instructions can access registei^s directly or 
indirectly with an 8-bit address field. The Z86C21 also 
allows short 4-bit register addressing using the Register 
Pointer (one of the control registers). In the 4-bit 
mode, the register file is divided into 16 working register 
groups, each occupying 16 contiguous locations (Figure 
6). The Register Pointer addresses the starting location 
of the active working-register group (Figure 7). Note: 
Register Bank EO-EF can only be accessed through 
working register and indirect addressing mode. 

Stacks. Either the internal register file or the external data 
memory can be used for the stack. A 16-bit Stack Pointer 
(R254 and R255) is used for the external stack, which can 
reside anywhere in data memory between locations 4096 
and 65535. An 8-bit Stack Pointer (R255) is used for the 
internal stack that resides within the 124 general-purpose 
registers (R4-R1 27). 
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6 
8 


5535 

192 
191 

\ 
12 

11 

10 


EXTERNAL 
ROM OR RAM 


LOCATION OF 

FIRST BYTE OF 

INSTRUCTION 

EXECUTED 

AFTER RESET 


ON-CHIP 
ROM 


»< 




IRQ5 




IRQ5 




IRQ4 




IRQ4 


INTERRUPT 


IRQ3 


VECTOR 
(LOWER BYTE) 


IRQ3 


>< 


IRQ2 


INTERRUPT 
VECTOR 


rf 


IRQ2 


IRQ1 




IRQ1 




IRQO 




IRQO 



8192 
8191 



EXTERNAL 

DATA 
MEMORY 



NOT ADDRESSABLE 



Figure 4. Program Memory Map 



Figure 5. Data Memory Map 



LOCATION 
255 
254 
253 
252 



247 
246 



STACK POINTER (BITS 7-0) 



STACK POINTER (BITS 15-8) 



REGISTER POINTER 



PROGRAM CONTROL FLAGS 



INTERRUPT MASK REGISTER 



INTERRUPT REQUEST REGISTER 



INTERRUPT PRIORITY REGISTER 



PORTS 0-1 MODE 



PORT 3 MODE 



PORT 2 MODE 



TO PRESCALER 



TIMER/COUNTER 



T1 PRESCALER 



TIMER/COUNTER 1 



GENERAL-PURPOSE 
REGISTERS 



IDENTIFIERS 

SPL 

SPH 

RP 

FLAGS 

IMR 

IRQ 

IPR 

P01M 

P3M 

P2M 

PREO 

TO 



TMR 
SIO 



THE UPPER NIBBLE OF THE REGISTER FILE ADDRESS 
- PROVIDED BY THE REGISTER POINTER SPECIFIES 
THE ACTIVE WORKING-REGISTER GROUP 



THE LOWER 
NIBBLE OF 
THE REGISTER 
FILE ADDRESS 
PROVIDED BY 
THE INSTRUCTION 
POINTS TO THE 
SPECIFIED 
REGISTER. 



Figure 6. The Register File 



Figure 7. The Register Pointer 
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SERIAL INPUT/OUTPUT 



Port 3 lines P3o and P3j can be programmed as serial I/O 
lines for full-duplex serial asynchronous receiver/transmitter 
operation. The bit rate is controlled by Counter/Timer 0. 

The Z86C21 automatically adds a start bit and two stop bits 
to transmitted data (Figure 8). Odd parity is also available as 
an option. Eight data bits are always transmitted, regardless 



of parity selection. If parity is enabled, the eighth' bit is the 
odd parity bit. An interrupt request (IRQ4) is generated on all 
transmitted characters. 

Received data must have a start bit, eight data bits and at 
least one stop bit. If parity is on, bit 7 of the received data is 
replaced by a parity error flag. Received characters 
generate the.lRQa interrupt request. 



TRANSMITTED DATA 

(No Parity) 



sp|d,|d6|d5|d4|d3|d2|Di|do|st| 



START BIT 
-EIGHT DATA BITS 
-TWO STOP BITS 



RECEIVED DATA 

(No Parity) 

'|D,|Dg[D5|D4|D3|D2|Di|Do|ST] 



L 



START BIT 
EIGHT DATA BITS 
ONE STOP BIT 



TRANSMITTED DATA 

(With Parity) 



SP[ p|Dg|D5|D4|D3|Da|D,|Do|ST| 

L 



START BIT 
SEVEN DATA BITS 
ODD PARITY 
TWO STOP BITS 



RECEIVED DATA 

(With Parity) 

SP|p|Dg|D5|D4|D3|D2|D,|Do|ST| 

L 



START BIT 
SEVEN DATA BITS 
PARITY ERROR FLAG 
ONE STOP BIT 



Figure 8. Serial Data Formats 



COUNTER/TIMERS 



The Z86C21 contains two 8-bit programmable counter/ 
timers (Tq and T-i), each driven by its own 6-bit 
programmable prescaler The Ti prescaler can be driven by 
internal or external clock sources; however, the Tq prescaler 
is driven by the internal clock only. 

The 6-bit prescalers can divide the input frequency of the 
clock source by any number from 1 to 64. Each prescaler 
drives its counter, which decrements the value (1 to 256) that 
has been loaded into the counter. When the counter reaches 
the end of count, a timer interrupt request— IRQ4 (Tq) or 
IRQ5 (Ti)— is generated. 

The counters can be started, stopped, restarted to continue, 
or restarted from the initial value. The counters can also be 
programmed to stop upon reaching zero (single-pass 
mode) or to automatically reload the initial value and 



continue counting (modulo-n continuous mode). The 
counters, but not the prescalers, can be read any time 
without disturbing their value or count mode. 

The clock source for T^ is user— definable and can be 
the internal nnicroprocessor clock divided by four, or an 
external signal input ' via Port 3. The Timer Mode 
register configures the external timer input as an 
external clock (IMHz maximum), a trigger input that 
can be retriggerable or non-retriggerable, or as a gate 
input for the internal clock. The counter/timers can be 
programmably cascaded by connecting the Tq output to 
the input of T^ Port 3 line P3g also serves as a 
timer output (Tqut) through which Tq, T^ or the 
internal clock can be output. 
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I/O PORT^ 



The ,.Z86C21 has 32 lines dedicated to input and output. 
These lines are grouped into four ports of eight lines each 
and are configurable as input, output or address/data. 
Under software control, the ports can be programmed to 
provide address outputs, timing, status signals, serial I/O, 
and parallel I/O with or without handshake. All ports have 
active pull-ups and pull-downs compatible with TTL loads. 

Port 1 can be programmed as a byte I/O port or as an 
address/data port for interfacing external memory. When 
used as an I/O port. Port 1 may be placed under handshake 
control. In this configuration. Port 3 lines P3 3 and P34 are 
used as the handshake controls RDY-i and DAV-i (Ready 
and Data Available). 

Memory locations greater than 8192 are referenced 
through Port 1 . To interface external memory. Port 1 must be 
programmed for the multiplexed Address/Data mode, if 
more than 256 external locations are required, Port must 
output the additional lines. 



Port 1 c_an be placed inthe high-impedance state along with 
Porto, AS, DS and R/W, allowing the Z86C21 to share 
common resources in multiprocessor and DMA 
applications. Data transfers can be controlled by assigning 
P33 as a Bus Acknowledge input, and P34 as a Bus Request 
output. 



<p^-- 



Z86C21 
MCU 



V HAND SHAKE CONTROLS 
> DAVi AND ROY1 
' (P33 AND P34) 



Figure 9a. Port 1 



Port can be programmed as a nibble I/O port, or as an 
address port for interfacing external memory. When used as 
an I/O port. Port may be placed under handshake control. 
In this configuration. P ort 3 lines P32 and P35 are used as 
the handshake controls DAVq and RDYq. Handshake signal 
assignment is dictated by the I/O direction of the upper 
nibble PO4-PO7. 

For external memory references. Port can provide address 
bits As-A-i 1 (lower nibble) or As-Ai 5 (lower and upper nibble) 
depending on the required address space. If the address 
range requires 1 2 bits or less, the upper nibble of Port can 
be programmed independently as I/O while the lower nibble 



is used for addressing. When Port nibbles are defined as 
address bits, they can be set to the high-impedance state 
along with Port 1 and the control signals AS, DS and R/W. 



Z86C21 
MCU 






. HAND SHAKE CONTROLS 
} DAVo AND RDYo 
' <P32 AND P35) 



Figure 9b. Port 



Port 2 bits can be programmed independently as input or 
output. This port is always available for I/O operations. In 
addition. Port 2 can be configured to provide open-drain 
outputs. 

Like Ports and 1, Port 2 may also be placed under 
handshake control. In this configuration, Port 3 line s P3i 
and P36 are used as the handshake controls lines DAV2 and 
RDY2. The handshake signal assignment for Port 3 lines P3-| 
and P36 is dictated by the direction (input or output) assigned 
to bit 7 of Port 2. 



Z86C21 
MCU 



^ HAND SHAKE CONTROLS 
} DAV2 AND RDY2 
' (P3i AND PSs) 



Figure 9c. Port 2 



Port 3 lines can be configured as I/O or control lines. In either 
case, the direction of the eight lines is fixed as four input 
(P3o-P33) and four output (P34-P37). For serial I/O, lines P3o 
and P37 are programmed as serial in and serial out 
respectively. 

Port 3 can also provide the follow ing control functions: 
handshake for Ports 0, 1 and 2 (DAV and RDY); four external 
interrupt request signals (IRQ0-IRQ3); timer input and output 
signals (Tin and Tqut) and Data Memory Select (DM). 













* 


Z86C21 


^ — 


MCU 




* 







Figure 9d. Port 3 
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INTERRUPTS 



The Z86C21 allows six different interrupts from eight sources: 
thefourPortS lines P3o-P33, Serial In, Serial Out, and the two 
counter/timers. These interrupts are both nnaskable and 
prioritized. The Interrupt Mask register globally or individually 
enables or disables the six interrupt requests. When more 
than one interrupt is pending, priorities are resolved by a 
programmable priority encoder that is controlled by the 
Interrupt Priority register 

All Z86C21 interrupts are vectored through locations in 
program memory. When an interrupt request is granted, 
an interrupt machine cycle is entered. This disables all 



subsequent interrupts, saves the Program Counter and 
status flags, and branches to the program memory 
vector location reserved for that interrupt. This memory 
location and the next byte contain the 16-bit address 
of the interrupt service routine for that particular 
interrupt request. 

Polled interrupt systems are also supported. To 
accommodate a polled structure, any or all of the interrupt 
inputs can be masked and the Interrupt Request register 
polled to determine which of the interrupt requests needs 
service. 



CLOCK 



The on-chip oscillator has a high-ga^n, parallel-resonant 
amplifier for connection to a crystal or to any suitable external 
clock source (XTAL1 = Input, XTAL2 = Output). 

The crystal source is connected across XTAL1 and XTAL2, 
using the recommended capacitors (Ci < 1 5 pi) from each 



pin to ground. The specifications for the crystal are as follows: 

■ AT cut, parallel resonant 

■ Fundamental type, 1 6 MHz maximum 

■ Series resistance, Rs < 1 00 Q 



GENERAL DESCRIPTION 



The Z86C12 development device allows users to proto- 
type a system with an actual hardware device and to 
develop the code. This code Is eventually mask-pro- 
grammed Into the on-chip ROM for any of the 86Cxx 
devices (except the 86C91). Development devices are 
also useful In emulator appli-cations where the final sys- 
tem configura-tlon - memory configuration, I/O, interr- 
upt inputs, etc. - are unknown.The Z86C1 2 development 
device is Identical to its equivalent Z86C2 1 microcomputer 
with the following exceptions: 

■ No internal ROM Is provided, so that code is 
developed In off-chip memory. Five "size" Inputs configure 
the memory boundaries. 



■ The normally internal ROM address and data lines are 
buffered and brought out to external pins to interface with 
the external memory. 

■ Control lines (/MAS and /MDS) are added to interface 
with external program memory. 

The Timing and Control, I/O ports, and clock pins on 
the Z86C12 are Identical In function to those on the 
86C21. This section covers those pins that do not 
appear on the Z86C21 8K ROM device. The pin 
functions and pin assignments are shown on figure 
00. 



Z86C12 PIN DESCRIPTION 

DO - D7 (Inputs, TIL compatible) Data bus. 
These 8 lines provide the Input data bus to access 
external memory emulating on the on-chip ROM. 
During read cycles in the internal memory space the 
data on these lines is latched in just prior to the rise of 
the /MDS data strobe. 

AO - A15 (Outpus TIL compatible) Address 
bus. During T1 these lines output the current memory 
address. All addresses, whether Internal or external, 
are output. 

/IVIAS (Output, TTL compatible) Memory 
Address Strobe. This line is active during every T1 
cycle. The rising edge of this signal may be us6d to 
latch the current memory address on the lines AO - 
A15. This line is always valid; It is not tri-stated when 
/AS Is tri-stated. 



/MDS (Output, TTL compatible) Memory Data 
Strobe. This is a timing signal used to enable the 
external memory to emulate the on-chip ROM. It Is 
active only during accesses to the on-chip ROM 
memory space, as selected by the configuration of the 
SIZEn pins. 

/SCLK (Output, TTL compatible) System 
Clock. This line is teh internal system clock. 

/SYNC (Output TTL, compatible) Sync signal. 
This signal indicates the last clock cycle of the currently 
executing instruction. 

/lACK (Output TTL, compatible) Interrupt 
Acknow-ledge. This output, when low, indicates 
that the Z86C12 is an interrupt cycle. 
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/SIZED, /SIZE1, /SIZE2, /SIZE3, SIZE4 
(Inputs, TTL compatible). The /SIZEn lines 
control the emulation mode of the 86C12. Note that 
/SIZED - /SIZE3 are active low, while SIZE4 is active 
high, the functions are defined as shown in figure 00. 
The 86C12 should be in RESET when the state of 
these lines are changed. 



NOTE: 



The SIZE pins may be configured to make the 
memory control signals (/MAS, /MDS, R/W, 
/AS, and /DS) look like the Z86C91 ROMIess 
device, however on power-up or reset ports 
D and 1 are configured as inputs, rather than 
A15 - A8 and AD7 - ADD, respectively. 







Table 1. 


Z86C12 Pin Assignments 






NAME 




NAME 


PIN 


NAME PIN 


NAME 


PIN 


/AS 


82 


A8 


J5 


PD7 J1 


P36 


A7 


/DS 


C4 


A9 


K4 


P1D G8 


P37 


A5 


/MAS 


El 


DD 


H3 


P11 G9 


R/W 


A1 


/MDS 


G3 


D1 


K2 


P12 G1D 


SCLK 


G2 


/RESET 


B3 


D2 


J3 


P13 F8 


SIZE4 


F1D 


/SIZED 


A3 


D3 


K3 


P14 D1D 


VCC 


A4 


/SIZE1 


C5 


D4 


H8 


P15 C1D 


VCC1 


B6 


/SIZE2 


A6 


D5 


J1D 


P16 B1D 


VCC2 


F9 


/SIZE3 


C6 


D6 


H9 


P17 E9 


VSS 


F3 


/SYNC 


F1 


D7 


H1D 


P2D C9 


VSS1 


E2 


AD 


J9 


lACK 


F2 


P21 A1D 


VSS2 


H6 


A1 


H7 


NC 


J2 


P22 B9 


VSS3 


E8 


A1D 


J4 


NC 


C3 


P23 C8 


Xtall 


B5 


A11 


H4 


NC 


D8 


P24 A9 


Xtal2 


A2 


A12 


K9 


NC 


H2 


P25 B8 


^ 




A13 


K7 


NC 


K1 


P26 A8 






A14 


K5 


PDD 


CI 


P27 C7 






A15 


H5 


PD1 


D3 


P3D B4 






A2 


KID 


PD2 


D2 


P31 B7 






A3 


J8 


PD3 


D1 


P32 C2 






A4 


J7 


PD4 


E3 


P33 D9 






A5 


K6 


PD5 


G1 


P34 E1D 






A6 


J6 


PD6 


HI 


P35 B1 






A7 


K8 













Table 2. Memory Size Configuration 



2 3 4 5 6 7 



9 10 



SiZE4 


/SIZES 


/SIZE2 


/SIZE1 


/SIZED 


MEMORY 


D 


1 




1 


1 


ROMIess 


D 


1 




1 


D 


2K ROM 


D 


1 




D 


1 


4K ROM 


D 


1 




1 


1 


8K ROM 


D 


D 




1 


1 


16KROM 


1 


1 




1 


1 


32K ROM 



c . 

D . 

E . 

F . 
G . 

■I . 

J . 
K . 



TOP V lEW 
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TIMING 

AND ^^- 

CONTROL -<- 



^JORTO 
(NIBBLE 
PROGRAM- 
MABLE) I/O 
OR A8-A15 



PORT 1 ^ ^ 

(BYTE PRO- -^ ^ 

GRAMMABLE) -^ ^ 

I/O OR -^ ^ 

AD0-AD7 ^ ► 



PROGRAM 
MEMORY 
DATA IN- 
PUTS 



ROM SIZE 
INPUTS 



STATUS AND -^- 
MEMORYCON--<- 
TROL .^-. 



GROUND 




CLOCK 



PORT 2 
(BIT PRO- 
GRAMMABLE) 



PORT 3 
SERIAL AND 
PARALLEL 
I/O CON- 
TROL 



PROGRAM 
MEMORY 
ADDRESS 
OUTPUTS 



POWER 



Z86C12 Pin Functions 
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INSTRUCTION SET NOTATION 



Addressing Modes. The following notation is used to 
describe the addressing modes and instruction operations 
as shown in the instruction summary. 

IRR Indirect register pair or indirect working-register 

pair address 

Irr Indirect working-register pair only 

X Indexed address 

DA Direct address 

RA Relative address 

IM Immediate 

R Register or working-register address 

r Working-register address only 

IR Indirect- register or indirect working-register 

address 

Ir Indirect working-register address only 

RR Register pair or working register pair address 

Symbols. The following symbols are used in describing the 
instruction set. 

dst Destination location or contents 

src Source location or contents 

cc Condition code (see list) 

@ Indirect address prefix 

SP Stack pointer (control registers 254-255) 

PC Program counter 

FLAGS Flag register (control register 252) 

RJP Register pointer (control register 253) 

IMR Interrupt mask register (control register 251 ) 



Assignment of a value is indicated by the symbol "^". For 
example, 

dst ^ dst -I- src 

indicates that the source data is added to the destination 
data and the result is stored in the destination location. The 
notation "addr(n)" is used to refer to bit "n" of a given 
location. For example, 

dst (7) 

refers to bit 7 of the destination operand. 

Flags. Control Register R252 contains the following six 
flags; 

C 

z 
s 

V 
D 
H 



Carry flag 
Zero flag 
Sign flag 
Overflow flag 
Decimal-adjust flag 
Half-carry flag 

Affected flags are indicated by: 

Cleared to zero 

1 Set to one 

* Set or cleared according to operation 

— Unaffected 

X Undefined 



CONDITION CODES 



Value 


Mnemonic 




Meaning 




Flags Set 


'1000 




Always true 




— 




0111 


c 


Carry 




C'= 1 




1111 


NC 


No carry 




C = 




0110 


z 


Zero 




Z = 1 




1110 


NZ 


Not zero 




z = o 




1101 


PL 


Plus 




8 = 0- 




0101 


Ml 


Minus 




8 = 1 




0100 


ov 


Overflow 




V = 1 




1100 


NOV 


No overflow 




V = 




0110 


EQ 


Equal 




Z= 1 




1110 


NE 


Not equal 




Z = 




1001 


GE 


Greater than 


or equal 


(8X0RV) 


= 


0001 


LT 


Less than 




(SXORV) 


= 1 


1010 


GT 


Greater than 




[Z0R(8X0RV)] = 


0010 


LE 


Less than or ^ 


equal 


[Z0R(8X0RV)] = 1 


1111 


UGE 


Unsigned greater than or equal 


C = 




0111 


ULT 


Unsigned less than 


C = 1 




1011 


UGT 


Unsigned greater than 


(C = OANDZ = 0)= 1 


0011 


ULE 


Unsigned less than or equal 


(CORZ) = 


= 1, 


0000 




Never true 




— 
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iNSTRUCTrON FORMATS 



1 



CCF, Dl, El, IRET, NOP, 
RCF, RET, SCF 



dst I OPCH INCr 

One— Byte Instructions 



OPC I MODE CLR, CPL, DA, DEC, 

RRC, SRA, SWAP 



OPC 



OR |l 1 1 0| dst I 



JP, CALL (Indirect) 



OPC 


MODE 


dst 


src 



MODE 


OPC 


dst/src 


src/dst 



ADC, ADD, AND, 
CP, OR, SBC, SUB, 
TCM, TM, XOR 



LD, LDE, LDEi, 
LDC, LDCI 



dst/src I OPC LD 

src/dst I OR |1 1 1 Oj src | 



dst/CC I OPc" 



OPC MODE 



OPC [MODE 



OR 


1110 


src 


OR 


1110 


dst 



ADC, ADD, AND, CP, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 



ADC, ADD, AND, CP, 

OR |i 1 1 ol dst I •-D. OR. SBC, SUB, 



MODE 1 


OPC 1 


src 


dst 



OR 


1110 


src 


OR 


1110 


dst 



MODE 


OPC 


dst/src 


X 


ADDRESS 1 



Two- Byte Instructions 



Three-Byte Instructions 



INSTRUCTION SUMMARY 



Instruction 
and Operation 




AddrMode 


Opcode 
Byte 
(Hex) 


Flags Affected 


dst src 


C Z S V D H 


ADC dst, src 

dst *- dst + src + 


C 


(Note1) 


in 


* * * * * 


ADD dst, src 
dst -^ dst + src 




(Note1) 


on 


* * * * It 


AND dst.src 

dst ^ dst AND src 




(Note1) 


5n 


— * * 


CALL dst 

SP-SP-2 
@SP *- PC; PC *- 


dst 


DA 
IRR 


D6 
D4 




CCF 

C-NOTC 






EF ' 


* 


CLR dst 

dst^O 




R 
IR 


BO 
B1 




COM dst . 

dst*- NOT dst 




R 
IR 


60 
61 


— * * 


CP dgt.srd 
dst - src 




(Note1) 


AD 


* * * * 



Instruction 
and Operation 


Addr Mode Opcode Flags Affected 


Byte 
dst src (Hex) C Z S V D H 


JPcc.dst 
if cc is true 
, PC*-dst 


DA cD 

c = ,0 - F 
IRR 30 



JRcc,dst 
if cc is true, 

PC *- PC + dst 
Range: +127, -128 



LD dst, src 
dst *- src 



RA cB 

c = 0- F 

r Im ' rC 

r R r8 

R r r9 

r = 0- F 

r X C7 

X r D7 

r Ir E3 

Ir r F3 

R R E4 

R IR E5 

R IM E6 

IR IM E7 

IR R F5 
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INSTRUCTION SUMMARY (Continued) 





AddrlVlode 


Opcode 
Byte 
(Hex) 


Flags Affected 


Instruction 
and Operation 


dst 


src 


C Z S V D H 


DA dst 

dst ^ DA dst 


R 
IR 




40 
41 


* * * X 


DEC dst 

dst ^ dst - 1 


R 
IR 




00 
01 


— * * * -r — 


DECW dst 

dst ^ dst- 1 


RR 
IR 




80 
81 


— * * * 


Di 

IMR(7)*-0 






8F 




DJNZ rdst 
r^r- 1 
ifr#0 

PC - PC + dst 
Range: +127, -128 


RA 




rA 
r = - F 




El 

IMR(7)^1 






9F 




HALT 






7F 




INC dst 

dst *- dst + 1 


r 

R 
IR 




rE 

r = 0- F 

20 

21 


— * * * 


INCWdst 

dst^dst+ 1 


RR 
IR 




AO 
A1 


— * * * 



IRET BF 

FLAGS ^@SP;SP^SP+ 1 

PC *- @SP; SP ^ SP + 2; IMR (7) *- 1 



****** 



RLC dst 



klHiIIIh'iR 



10 * * * * 

11 



RRdsti 1 . I R 

4ll4EI^|R 



EO * * * * 

El 



RRCdst 



t^HEZU^iR 



IR 



CO * * * * 

CI 



SBCdst.src (Notel) 

dst ^ dst ^ src -*- C , 



SD * * * * 1 * 



SCF 

C-1 



DF 1 



SRAdst|j_,_r-T JR 



DO * * * 
D1 



SRP src 

RP ^ src 



Im 



31 



STOP 



6F 



SUBdst.src (Notel) 

dst *- dst -*- src 



2n * * * * 1 * 



SWAP dst . 



MR 



FO X * * X 

F1 



TCIVI dst, src 
(NOT dst) AND src 



(Notel) 



en 



* * 



Instruction 
and Operation 


i 


(VddrMode 


Opcode 
Byte 
(Hex) 


Flags Affected 


dst 


src 


C Z S V D H 


LDC dst,src 
dst ^ src 




r 
Irr 


Irr 

r 


C2 
D2 




LDCI dst, src 

dst ^ src 

r ^ r + 1 ; rr *- rr + 


1 


Ir 
Irr 


Irr 
Ir 


C3 
D3 




LDE dst,src 
dst *- src 




r 
Irr 


Irr 
r 


82 
92 




LDEI dst,src 

dst *- src 

r *- r + 1 ; rr ^ rr + 


1 


Ir 
Irr 


Irr 
Ir 


83 
93 




NOP 








FF 




OR dst, src 

dst *- dst OR src 




(Notel) 


4n 


- * * 


POP dst 

dst ^ @SP; 
SP^SP + 1 




R 
IR 




50 
51 




PUSH src 

SP-SP- 1;@SP*- 


src 


R 
IR 


70 
71 




RCF 

C-0 








CF 





RET 

PC ^ @SP; SP *- 1 


3P 


+ 2 




AF 








R 
IR 




90 

91 




RL dst 1 


bJ 


* * * * 


jclO-l. 








TM dst, src 
dst AND src 




(Notel) 


7n 


- * * 


XOR dst,src 
dst^dstXORsrc 




(Notel) 


BD, 


- * * 



NOTE: These instructions have an identical set of addressing nnodes, 

which are encoded for brevity, the first opcode nibble is found in 
the instruction set table above. The second nibble is expressed 
symbolically by a D in this table, and its value is found in the 
following table to the left of the applicable addressing mode pair 
For example, the opcode of an ADC instruction using the 
addressing modes r (destination) and Ir (source) is 13. 

dst src Opcode Nibble 

~ r r E 

r Ir [3] 

R. R H 

R IR [5] 

R IM [6] 

IR IM 



145 



REGISTERS 



R240SIO 
SERIAL I/O REGISTER 

(FOh; Read/Write) 

|d7|dJd5|d4|d3|d2|Di|Do| 



R244 TO 
COUNTER/TIMER REGISTER 

(F4h; Read/Write) 

|d,|d6|d5|d4|d3|d^|d, IdqI 



- SERIAL DATA (Do = LSB) 



To INITIAL VALUE (WHEN WRITTEN) 

-(RANGE: 1-256 DECIMAL 01-00 HEX) 

To CURRENT VALUE (WHEN READ) 



R241 TMR 
TIMER MODE REGISTER 

(F1h; Read/Write) 



R245 PREO 
PRESCALERO REGISTER 

(F5h; Write Only) 



Tout MODES 

NOT USED = 00 

To OUT = 01 

T, OUT = 10 

INTERNAL CLOCK OUT = 11 

T,N MODES 

EXTERNAL CLOCK INPUT ?= 00 

GATE INPUT = 01 

TRIGGER INPUT = 10 

(NONRETRIGGERABLE) 

TRIGGER INPUT = 11 
(RETRIGGERABLE) 



F 


DelDs 


D4ID3ID2ID, |Do| 








L 



= NO FUNCTION 
= LOADT, 

= DISABLE T, COUNT 
" 1 = ENABLE T, COUNT 



|D3|D2|Di|Doi 



1 = To MODULON 



PRESCALER MODULO 
-(RANGE: 1-64 DECIMAL 
01-00 HEX) 



R242T1 
COUNTER TIMER 1 REGISTER 

(F2h; Read/Write) 

JD^lDglDslD^lDalD^lDiTDn 



R246 P2M 
PORT 2 MODE REGISTER 

(F6h; Write Only) 

|D,|Dg|Ds|D4|D3[Da|D,|D7| 



T, CURRENT VALUE (WHEN READ) 



P2o-P27 I/O DEFINITION 
- DEFINES BIT AS OUTPUT 
1 DEFINES BIT AS INPUT 



R243 PRE1 
PRESCALER 1 REGISTER 

(F3h; Write Only) 



I D; I Dg I D; D4 I D3 I D; I D, I Dp I 



count mode 
- = t, single-pass 
1 = t, modulon 

clock source 
_ 1 = t, internal 
= ti external timing input 
(t,n) mode 

prescaler modulo 
-(range: 1-64 decimal 

01-00 HEX) 



R247 P3M 
PORT 3 MODE REGISTER 

(F7h; Write Only) 



H 



De M>s D4 



3|D2|Di|d 



L. 



— RESERVED 






_ P32 = INPUT 


P35 = 
P35 = 


OUTPUT 


1 P32 = DAVO/RDYO 


RDYO/DAVO 


P33 = INPUT 


P34 = 


OUTPUT 


° I } P33 = INPUT 


P34 = 


Blvi 


11 P33 = DAV1/RDY1 


P34 = 


RDY1/DAV1 



Figure 1 1 . Control Registers 
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REGISTERS (Continued) 



R248P01M 
PORT AND 1 MODE REGISTER 

(F8h; Write Only) 



E 



PO4-PO7 MODE 
OUTPUT = 00 
INPUT = 01 
A12-A1S = IX 

EXTERNAL MEMORY TIMING 
NORMAL = - 
EXTENDED = 1 



T 



DsIPjIDiIDqI 



T 



PQ0-PO3 MODE 

00 = OUTPUT 

01 = INPUT 
IX = Ae-A„ 

STACK SELECTION 

- = EXTERNAL 

I = INTERNAL 

PI0-PI7 MODE 
00 = BYTE OUTPUT 

- 01 = BYTE INPUT 
10 = AD0-AO7 

II = HIQHJMPEDANCE AD0-AD7, 

AS, DS, R/W, Aa-Aii, Ai2-Ai5 
IF SELECTED 



R252 FLAGS 
FLAG REGISTER 

(FCh; Read/Write) 



EH 



D5 1 P4 1 D3 1 P2 



PiIPqI 



L^ 



USER FLAG F1 

USER FLAG F2 
-HALF CARRY FLAG 
-DECIMAL ADJUST FLAG 
-OVERFLOW FLAG 



-CARRY FLAG 



R249 IPR 
INTERRUPT PRIORITY REGISTER 

(F9h; Write Only) 



Dt I Dg I D5 I D4 I D3 I Da I Di [pTI 



IRQ3, IRQ5 PRIORITY (GROUP A) 

= IRQ5 > IRQ3 - 

1 = IRQ3 > IRQ5 

IRQO, IRQ2 PRIORITY (GROUP B) 

= IRQ2 > IRQO - 

1 = IRQO > IRQ2 

IRQI, IRQ4 PRIORITY (GROUP C) 

= IRQI > IRQ4 - 

1 = IRQ4 > IRQI 



A > B > C = 010 



R253 RP 
REGISTER POINTER 

(FDh; Read/Write) 

|D,|De|D5|D4|D3|D;[D,|Do| 

"il 

h 1 



DON'T CARE 



R250 IRQ 
INTERRUPT REQUEST REGISTER 

(FAh; Read/Write) 



I D; I Ds I D5 I D4 I D3 I Da I D, I Do"| 

.=1 czz 



R254 SPH 
STACK POINTER 

(FEh; Read/Write) 

|D7|D6|D5|D4|D3|Da|D^|Do| 



IRQO = P32 INPUT (Do = IRQO) 

IRQI = P33 INPUT 

IRQ2 = P3i INPUT 

IRQ3 = P3o INPUT, SERIAL INPUT 

IRQ4 = To, SERIAL OUTPUT 

IRQ5 = Ti 



STACK POINTER UPPER 
" BYTE (SPg-SPis) 



R251 IMR 
INTERRUPT MASK REGISTER 

(FBh; Read/Write) 



I D, I Ds I D5 I D4 I D3 I Da I D, I Dp"] 



R255SPL 
STACK POINTER 

(FFh; Read/Write) 

|d7|d6|d5|d4|d3|d2|d,|do| 



1 ENABLES IRQ0-IRQ5 
" (Do = IRQO) 

- RESERVED 

-1 ENABLES INTERRUPTS 



Figure 1 1 . Control Registers (Continued) 
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OPCODE MAP 



Lower Nibble (Hex) 
6 7 8 



1 

z 

I 8 

a 

3 



65 


6 5' 


6,5 


6.5 


10.5 


105 


10.5 


10.5 


6.5 


6.5 


12/10.5 


12/10.0 


6.5 


12/10.0 


6.5 




DEC 


DEC 


ADD 


ADD 


ADD 


ADD 


ADD 


ADD 


LD 


LD 


DJNZ 


JR 


LD 


JP 


INC 




Rl 


iRi 


ri,r2 


ri,lr2 


R2.R1 


IR2.R1 


Rl IM 


IR1.IM 


ri.R2 


r2.Rl 


ri RA 


ccRA 


ri.lM 


cc.DA 


rl 




6,5 


' 65 


6.5 


6.5 


10.5 


10.5 


10.5 


, 10,5 
































RLC 


RLC 


ADC 


ADC 


ADC 


ADC 


ADC 


ADC 
































Rl 


IRi 


ri,r2 


ri.lr2 


R2.R1 


IR2,Ri 


R1.IM 


IRl,IM 
































6,5 


6.5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 




INC 


INC 


SUB 


SUB 


SUB 


SUB 


SUB 


SUB 


























• 






Rl 


IRi 


ri.r2 


ri.lr2 


R2.R1 


IR2.R1 


Rl,IM 


IR1.IM 
































8,0 


6,1 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 




JP 


SRP 


SBC 


SBC 


SBC 


SBC 


SBC 


SBC 
































IRRl 


, IM 


ri.r2 


ri,lr2 


R2.R1 , 


IR2,Ri 


Rl,IM 


IRl,IM 
































8.5 


8,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 




DA 


DA 


OR 


OR 


OR 


OR 


OR 


OR 
































Rl 


IRi 


ri.r2 


riJr2 


R2.R1 


iR2.Ri 


Rl,IM 


IRl,IM 
































10,5 


10,5 


6,5 


6.5 


10,5 


10,5 


10,5 


10,5 




POP 


POP 


AND 


AND 


AND 


AND 


AND 


AND 
































Rl 


IRi 


ri.r2 


ri.lr2 


R2.R1 


IR2.R1 


Rl.lM 


IRl,IM 
































6,5 


6,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 


6,0 


COM 


COM 


TCM 


TCM 


TCM 


TCM 


TCM 


TCM 






























STOP 


Rl 


iRi 


ri,r2 


ri,lr2 


R2.R1 


IR2,Ri 


Rl.lM 


IRl,IM 
































10/12,1 


12/14,1 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 


7,0 


PUSH 


PUSH 


TM 


TM 


TM 


TM 


TM 


TM 






























HALT 


R2 


IR2 


n.ra' 


ri.lr2 


R2.R1 


IR2.R1 


Rl,IM 


IRl,IM 
































10,5 


10,5 


12,0 


18,0 










6,1 


DECW 


DECW 


LDE 


LDEi 






































Dl 


RRi 


IRi 


ri,lrr2 


iri.lrr2 








































6,5 


6,5 


12,0 


18,0 










6,1 


RL 


RL 


LDE 


LDEI 






































Ei 


Ri 


IRi 


r2,lrri 


Ir2.lrri 








































10,5 


10,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 


14.0 


INCW 


INCW 


CP 


CP 


CP 


CP 


CP 


CP 






























RET 


RRl 


IRi 


ri,r2 


ri.lr2 


R2.R1 


IR2.R1 


R1.IM 


lRi,IM 
































6,5 


6,5 


6.5 


"6,5 


10,5 


10,5 


10.5 


"10,5 , 


16.0 


CLR 


CLR 


XOR 


XOR 


XOR 


XOR 


XOR 


XOR 






























IRET 


Rl 


IRi 


ri.r2 


^\M2 


R2.R1 


IR2,Ri 


R1.IM 


IRl,IM 
































6,5 


6,5 


12,0 


18,0 








10,5 


6.5 


RRC 


RRC 


LDC 


LDCI 








LD 






























RCF 


Rl 


IR1 


ri,lrr2 


Iri,lrr2 








ri,x.R2 
































6,5 


6,5 


12.0 


18,0 


20,0 




20,0 


10,5 


6.5 


SRA 


SRA 


LDC 


LDCI 


CALL* 




CALL 


LD 






























SCF 


Ri 


IRi 


r2,lrri 


Ir2,lrri 


IRRl 




DA 


r2,x,Ri 
































6,5 


6,5 




6,5 


10,5 


10,5 


10,5 


10,5 


6.5 


RR 


RR 




LD 


LD 


LD 


LD 


LD 






























CCF 


Ri 


IRi 




ri,IR2 


R2.R1 


IR2,Ri 


R1.IM 


IRl,IM 
































8,5 


8,5 




6,5 




10,5 






6.0 


SWAP 


SWAP 




LD 




LD 


































NOP 


Rl 


IRi 




Iri.r2 




R2,IRi 






\ 


1 


' 


r 


\ 


f 


^ f 


\ 


r 


\ 


r 


\ 


1 





LOWER 
OPCODE 
NIBBLE 



Bytes per instruction 



EXECUTION 
CYCLES 



V^ 



PIPELINE 
CYCLES 



UPPER 

OPCODE - 

NIBBLE 



10,5 
CP 

R2.R1 



FIRST, 
OPERAND 



A^ 



SECOND 
OPERAND 



Legend: 

R = 8-bit address 
r = 4-blt address 
Riorri = Dst address 
R2 or r2 = Src address 

Sequence: 

Opcode, First Operand, Second Operand 

NOTE: The blank areas are not defined. 



'2-byte instruction; fetch cycle appears as a 3-byte instruction 
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ABSOLUTE MAXIMUM RATINGS 

Voltages on all pins with respect 

toGND -0.3Vto +7.0V 

Operating Ambient 

Temperature . . .' See Ordering Information 

Storage Temperature -65°Cto +150°C 

STANDARD TEST CONDITIONS 

The DC characteristics listed below apply for the following 
standard test conditions, unless otherwise noted. All 
voltages are referenced to GND. Positive current flows into 
the referenced pin. 

Standard conditions are as follows: 

■ +4.5 < Vcc ^ + 5.5V 

■ GND = OV ^ 

■ C < T;^ < +70 C for S (Standard temperature) 



Stresses greater than those listed under Absolute Maximum Ratings may 
cause permanent damage to the device. This is a stress rating only; 
operation of the device at any condition above those indicated in the 
operational sections of these specifications is not implied. Exposure to 
absolute maximum rating conditions for extended periods may affect 
device reliability. 



FROM OUTPUT f. 
UNDER TEST '"^ 



150 pFS: 



Figure 12. Test Load 1 




DC CHARACTERISTICS 



Symbol 


Parameter 


Min TVp 


Max 


Unit 


Condition 


VCH 


Clock Input High Voltage 


3.8 


Vcc 


V 


Driven by External Clock Generator 


VCL 


Clock Input Low Voltage 


-0.3 


0.8 


V 


Driven by External Clock Generator 


V|H 


Input High Voltage 


2.0 


Vcc 


' V 




VlL 


Input Low Voltage 


-0.3 


0.8 


V 




Vrh 


Reset Input High Voltage 


3.8 


Vcc 


V 




Vrl 


Reset Input Low Voltage 


-0.3 


0.8 


V 




VOH 


Output High Voltage 


2.4 




V 


Ioh=-250mA 


VOH 


Output High Voltage 


Vcc -lOOmV 




V 


Ice = -IOOmA 


Vol 


Output Low Voltage 




0.4 


V 


Iql = + 2.0 mA 


tlL 


Input Leakage 


-10 


10 


mA 


OV<V|N< + 5.25V 


'OL 


Output Leakage 


-10 


10 


mA 


OV<V|N< + 5.25V 


l|R 


Reset Input Current 




-50 


mA 


Vcc= + 5.25V. Vrl = OV 


'cc 


Supply Current 






mA 


All outputs and I/O pins floating , 1 2 MHz 


'CCi 


Standby Current 


5 




mA 


Halt Mode 


ICC2 


Standby Current 




10 


mA 


Stop Mode 



*CC2 requires loading TMR (%F1) with any value prior to STOP execution. 

Use the sequence: 

LD TMR, #00 

NOP 

STOP 
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% 



-KiD^ 



PORT O, 
DM 



X 



y. 



-<i> 



"Wf 



0-A7 ^ 



DS 

(READ) 



X 



-<D- 



^: 



-<!>- 



-<!>- 



3C 



\ 



-(jy 






r 



^►-^sK 



K 



:r 



Figure 13. External I/O or Memory Read/Write 



AC CHARACTERISTICS 

External I/O or Memory Read and Write Timing 









12MHz 


I6MH2 


2OMH2 






Number Symbol 


Parameter 


Min 


Max 


Min 


Max 


Min 


Max 


Units 


Notes 


1 


TdA(AS) 


Address Valid to AS tDelay 


35 




25 




20 




ns 


2,3,4 


2 


TdAS(A) 


AStto Address Float Delay 


45 




35 




25 




ns 


2,3,4 


3 


TdAS(DR) 


AStto Read Data Req'd Valid 




250 




180 




150 


ns 


1,2,3,4 


4 


TwAS 


AS Low Width 


55 




40 




30 




ns 


2,3.4 


5 


TdAZ(DS) 


Address Float to DSI 

















ns 




6 


TwDSR 


DS (Read) Low Width 


185 




135 




105 




ns 


1,2,3,4 


7 


TwDSW 


DS (Write) Low Width 


110 




80 




65 




ns 


1,2,3,4 


8 


TdDSR(DR) 


DSito Read Data Req'd Valid 




130 




75 




55 


ns 


1,2,3,4 


9 


ThDR(DS) 


Read Data to DStHold Time 

















ns 


2,3,4 


10 


TdDS(A) 


DB t to Address Active Delay 


65 




50 




40 




ns 


2,3,4 


11 


TdDS{AS) 


DStloASiDelay 


45 




35 




25 




ns 


2,3,4 


12 


TdR/W(AS) 


RW Valid to ASt Delay 


33 




25 




20 




ns 


2,3,4 


13 


TdDS(R/W) 


DSttoR/W Not Valid 


50 




35 




25 




ns 


2,3,4 


14 


TdDW(DSW) 


Write Data Valid to DSi(Write) Delay 


35 




25 




20 




ns 


2,3,4 


15 


TdDS(DW) 


pstto Write Data Not Valid Delay 


55 




35 




25 




ns 


2,3,4 


16 


TdA(DR) 


Address Valid to Read Data Req'd Valid 




310 




230 




180 


ns 


1,2,3.4 


17 


TdAS(DS) 


AS tloDSi Delay 


65 




45 




35 




ns 


2,3,4 


18 


TdDI(DS) 


Data Input Setup to DS t 


75 




60 




50 




ns 


1,2,3,4 


19 


TdDM(AS) 


DM Valid to AS i Delay 


50 




30 




20 




ns 


2,3,4 



Notes 

1 . When using extended memory timing add 2TpC 

2. Timing numbers given are for minimum TpC 

3. See clock cycle dependent characteristics table 

4. 20 MHz timing is preliminary and sirt^ject to change 



+ Test Load 1 

» All timing references use 2.0V for a 
logic "1" and 0.8V for a logic "0" 
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AC CHARACTERISTICS 










Additional Timing Table 


















12 MHz 


16 MHz 


20 MHz 




Number 


Symbol 


Parameter 


Min Max 


Min Max 


Min Max 


Notes 


1 


TpC 


Input Clock Period 


83 1000 


62.5 1000 


50 1000 


1 


2 


TrC.TfC 


Clock Input Rise & Fall Times 


15 


10 


10 


1 


3 


TwC 


Input Clock Width 


37 


21 


15 


1 


4 


TwTlnL 


Timer Input Low Width 


75 


75 


75 


2 


5 


TwTinH 


Timer Input High Width 


3TpC 


3TpC 


3TpC 


2 


6 


TpTin 


Timer Input Period 


8TpC 


8TpC 


8TpC 


2 


7 


TrTin.TfTin 


Timer Input Rise and Fall Times 


100 


100 


100 


2 


8A 


TwIL 


Interrupt Request Input Low Time 


70 


70 


70 


2,4 


8B 


TwIL 


Interrupt Request Input Low Time 


3TpC 


3TpC 


3TpC 


2,5 


9 


TwIH 


Interrupt Request Input High Time 


3TpC 


3TpC 


3TpC 


2,3 



Notes: 

1 . Clock timing references use 3.8 V for a logic "1" and 0.8 V for a logic "0" 

2. Timing references use 2.0 V for a logic "1 " and 0.8 V for a logic "0" 

3. Interrupt references request via Port 3 

4. Inten-upt request via Port 3 (P3, - P33) 

5. Interrupt request via P30 

6. 20 MHz timing is preliminary arxJ subject to change. 
Units in nanosecorxls (ns) 



5av 



X 



t.j k 



»-^l/" 



u — 



xz. 



-4 



NEXT DATA IN VAUD 



DALAYED RDY 



■^e- 



Figure 15a. Input Handshake Timing 



DATA OUT 



X 



DATA OUT VAUD 



U J 



X 



U 8 J < • > 



-10— >| 



^ 



ii 

NEXT DATA OUT VAUD 

ss 

DELAYED DAV | X 

— 55 7 

DELAYED RDY . 



Figure 15b. Output Handshake Timing 
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.DO gl 
. P2 23 



J23__21 



. D4 2& 



. D6 27 
■ D7 28 



AO 13 



_A1 11 



A2 15 



_A2 m 



A4 17 



_AS m 



_iiS IS 



A7 20 






PIO 




P20 


PU 




P21 


P12 




P22 


P13 




P23 


P14 




P24 


P15 


r -> 


P25 


P16 


P26 


P17 


P27 



3Q 



POO 
POl 
P02 
P03 
P04 
P05 
P06 
P07 



O 
C/Q 

T-H 

W 
CO 
CX) 
M 



P30 
P31 
P32 
P33 
P34 
P35 
P36 
P37 



R/W VCC 

AS GND 

m XTALl 

HEsFr 



XTAL2 



21- 



3SL. 



33 



34 



39 



12 EPM 



30 VPP 



^X 

JilX 

^x 

^X 

1 VCC 



11 



•^X 



-z±r 



IK Ohm 

-vwv- 

IK Ohm 

-A/WV- 



^AO 10 



.Al 8. 



s A2 e 



sA3 7 



s A& & 



A6 4 



U7 3 



IK Ohm 

-^AAAr- 



r 



12.5 / 
VOLT 



lOK Ohm 

-AANV- 



_21. 



_2L 



-23. 



-^ 



-^ 



-^ 



AO 

Al 

A2 

A3 

A4 

A5 

A6 

A7 

A8 

A9 

AlO 

All 

A12 

PGM 

CS 

OE 



O 
O 
CO 

CD 
O 



n 


DP 


12 


D1 


13 


D2 


15 


D3 


10 


D4 


17 


D5 


19 


D6 


19 


D7, 



VCC 
VPP 



-a 



-o 



EXTERNAL 

POWER 

SUPPLY 



I 



RECOMMENDED VOLTAGE: 12.5Volts 



Z86E21 Z8 OTP Programming Adapter 



-(i>- 



-"^-nw^ 



-0—1 




/ 



Figure 14. Additional Timing 
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AC CHARACTERISTICS 

Handshake Timing 



Number Symbol 



Parameter 



12,16,20 MHz 
Min Max 



Notes (Data Direction) 



1 


TsDI(DAV) 


Data In Setup Time 







In 


2 


ThDI(DAV) 


Data In Hold Time 


145 




In 


3 


TwDAV 


Data Available Width 


110 




In 


4 


TdDAV(RDY) 


DAVito RDYiDelay 




115 


In 


5 


TdDAV(RDY) 


DAVttoRDYt Delay 




115 


In 


6 


TdRDY(DAV) 


RDYttoDAVi Delay 







In 


7 


TdDO(DAV) 


DataOuttoDAViDelay 


TpC 




Out 


8 


TdDAVd(RDY) 


DAVItoRDYIDelay 







Out 


9 


TdRDY(DAV) 


RDYitoDAVtDelay 




115 


Out 


10 


TwRDY 


RDY Width 


110 




Out 


11 


TdRDY(DAV) 


RDYtto DAViDelay 




115 


Out 



CLOCK DEPENDENT AC CHARACTERISTICS 

External I/O or Memory Read and Write Timing 



Number 


Symbol 


Equation 


1 


TdA(AS) 


0.4TpC+0.32 


2 


TdAS(A) 


0.59TpC-3.25 


3 


TdAS(DR) 


2.83TpC+6.14 


4 . 


TwAS 


0.66TpC-1.65 


6 


TwDSR 


2.33TpC-10.56 


7 


TwDSW 


1.27TpC+1.67 


8 


TdDSR(DR) 


1.97TpC-42.5 


10 


TdDS(A) 


0.8TpC 


11 


TdDS(AS) 


0.59TpC-3.14 


12 


TdRM(AS) 


0.4TpC 


13 


TdDS(R/W) 


0.8TpC-15 


14 


TdDW(DSW) 


0.4TpC 


15 


TdDS(DW) 


0.88TpC-19 


16 


TdA(DR) 


4TpC-20 


17 


TdAS(DS) 


0.91TpC-10.7 


18 


TsDI(DS) 


0.8TpC-10 


19 


TdDM(AS) 


0.9TpC-26.3 
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^ZiKJG 



Preliminary Product Specification 



May 1989 



Z86C27 DTC, 
Z86C97 DTC 

Digital Television Controllers 



FEATURES 

■ CMOS technology operating over a 3 to 6 volt power 
supply range. 

■ Complete single-chip microconnputer: 

8 bit Z8 core processor with 256 byte register file, 
Watch Dog Tinner, Power On Reset, Brown-out 
protection, 43 I/O lines and 2 channel Counter/ 
Timer. 

8K byte internal program ROM (Z86C27) or 64K 
byte external program/data memory interface 
(Z86C91). 

■ On-Screen Display video controller: 

20 character by 6 row screen format 
12 by 15 pixel character cell 



Mask programmable 128 character typeface with 
English, Korean, Chinese and Japanese ROM-less 
versions available. 

Programmable color attributes including row 
character, row background/fringe, frame 
background, and bar graph color change. 

Programmable display position and character size 
control. 

13 Pulse Width Modulator outputs for digital to analog 
conversion - require a simple external RC low pass 
filter. 

12 volt open drain outputs 

14-, 8- and 6-bit resolutions 



GENERAL DESCRIPTION 

The Z86C27 and Z86C97 are CMOS Application Specific 
Standard Product microcomputers that integrate special- 
ized peripheral functions (normally provided by external 
components) for the control of color television related 
products. Utilizing Zllog's advanced Superintegration™ 
design methodology, these devices provide an ideal cost, 
performance and reliability solution for consumer and 
industrial television applications. 



The devices have an 8 bit internal data path controlled by 
a Z8 microcontroller core with 256 bytes of register space. 
On-chip peripherals include a two channel Counter/Timer, 
an On-Screen Display video controller, a 13 Channel 
Digital-to-Analog converter and comprehensive Input/Out- 
put ports. The Z86C27 is the mask-ROM high volume 
production device embedded with a custom (customer 
supplied) program of up to 8 K bytes in size (Figure 1 ). The 
Z86C97 is the ROM-less version for prototyping and low 
volume production (Figure 2). 



155 



PIN CONFIGURATIONS 



PWM5 


C 


^ 64 


3 


PWM6 


*PWM4 


c 


2 


63 


3 


PWM7 


PWM3 


c 


3 


62 


3 


PWM8 


PWM2 


E 


4 


61 


3 


PWM9 


PWM1 


C 


5 


60 


3 


PWM10 


P35 


C 


6 


59 


3 


PWM11 


P36 


C 


7 


58 


3 


PWM12 


P34 


C 


8 . 


57 


3 


PWM13 


P31 


C 


9 


56 


3 


P27 


P30 


C 


10 


55 


3 


P26 


XTAL1 


C 


11 


54 


3 


P25 


XTAL2 


c 


12 


53 


3 


P24 


RESET 


c 


13 


52 


3 


P23 


P60 


c 


14 


51 


3 


Vss 


Vss 


c 


15 


50 


3 


P22 


P61 


c 


16 


49 


3 


P21 


P62 


c 


17 


48 


3 


Vcc 


Vcc 


c 


18 


47 


3 


P20 


P63 


c 


19 


46 


3 


P47 


P64 


c 


20 


45 


3 


P46 


P65 


c 


21 


44 


3 


P45 


AFCIN 


E 


22 


43 


3 


P44 


P50 


E 


'23 


42 


3 


P43 


P51 


E 


24 


41 


3 


P42 


P52 


E 


25 


40 


3 


P41 


P53 


E 


26 


39 


3 


P40 


P54 


E 


27 


38 


3 


VBLANK 


P55 


E 


28 


37 


3 


VBLUE 


P56 


E 


29 


36 


3 


VGREEN 


P57 


E 


30 


35 


3 


VRED 


OSCIN 


E 


31 


34 


3 


VSYNC 


OSCOUT 


E 


32 


33 


3 


HSYNC 



64 


3 


PWM6 


63 


3 


PWM7 


62 


3 


PWM8 


61 


3 


PWM9 


60 


3 


PWM10 


59 


3 


PWM11 


58 


3 


PWM12 


57 


3 


PWM13 


56 


3 


P27 


55 


3 


P26 


54 


3 


P25 


53 


3 


P24 


52 


3 


P23 


51 


3 


Vss 


50 


3 


P22 


49 


3 


P21 


48 


3 


Vcc 


47 


3 


P20 


46 


3 


P17 


45 


3 


P16 


44 


3 


PI 5 


43 


3 


P14 


42 


3 


P13 


41 


3 


P12 


40 


3 


P11 


39 


3 


P10 


38 


3 


VBLANK 


37 


3 


VBLUE 


36 


3 


VGREEN 


35 


3 


VRED 


34 


3 


VSYNC 


33 


3 


HSYNC 



Figure 1. Z86C27 mask-ROM Plastic Dip 



Figure 2. Z86C97 ROlVI-less Piastic DIP 
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PIN IDENTIFICATION 
Z86C27 mask-ROM 



Pin 



Name 



Function 



PWMg-PWM, 



1-5 

6,7,8 PSg. P3e, P34 

9. 10 P3,, P3o 

11, 12 XTAL^. XTALg 



Pulse Width Modulator Output 
Port 3 Outputs 
Port 3 Inputs 
Microcontroller Crystal Oscillator 



13 
14 
15 
16. 



RESET(Testl) 
P6„ 



17 



P6., 



P6o 



System Reset (Testi) Input 
Port 6 bit Input 
Power Supply Ground 
Port 6 bits 1 and 2 Input 



^8 . V,, 

19-21 P63-P65 

22 AFC,^ 

23-30 P5o^P57 



Power Supply Positive 
Port 6 bits 3 thru 5 Input 
AFC Analog Input 
Port 5 bits 0-7, Output (LED) 



31,32 OSC,^,OSCo^^ Video Dot Clock Oscillator 

^^ ^sYNc Horizontal Sync Input 

^^ ^sYNc Vertical Sync Input 

35 V„_ Video Red Output 



36 
37 
38 
39-46 



^GREEN 
^BLUE 

V 

^ BLANK 

P4.-P4, 



Video Green Output 
Video Blue Output 
Video Blank Output 
Port 4 bits 0-7, Output 



47 P2, 

48 V^ 
49,50 P2,.P22, 
51 V... 



Port 2 bit 0,1/0 
Power Supply Positive 
Port 2 bits Land 2. I/O 
Power Supply Ground 



52-56 P23-P27 Port 2 bits 3 thru 7, I/O 

57-64 PWM.3-PWMg Pulse Width Modulator Output 



Z86C97 ROM-less 



Pin 


Name 


Function 


1-5 


PWMg-PWM^ 


Pulse Width Modulator Output 


6.7,8 


P3,. P3,. P3, 


Port 3 Outputs 


9, 10 


P3,. P3, 


Port 3 Inputs 


11, 12 


XTAL^, XTALg 


Microcontroller Crystal Oscillator 








13 


RESET(Testl) 


System Reset (Testi) Input 


14 


AS 


Address Strobe, Output 


15 


Vas 


Power Supply Ground 


16 


^ 


Data Strobe, Output 


17 


R/W 


Read/Write. Output 


18 


Vcc 


Power Supply Positive 


19 


ScLK 


System Clock, Output 


20.21 


P6,, P6, 


Internal AFC Comparator (Out) 


22 


AFC,^ 


AFC Analog Input 


23-30 


POo-PO, 


Port bits 0-7, Output (A. , J 


31,32 


OSC,^, OSCq^^ Video Dot Clock Oscillator 


33 


•^SYNC 


Horizontal Sync Input 


34 


V 
SYNC 


Vertical Sync Input 


35 


Vred 


Video Red Output 


36 


V 

^ GREEN 


Video Green Output 


37 


Vbu^e 


Video Blue Output 


38 


V 

BLANK 


Video Blank Output 


39-46 


PI0-PI7 


Port 1 bits 0-7, Output (AD^,) 


47 


P2o 


Port 2 bit 0, I/O 


48 


Vcc 


Power Supply Positive 


49,50 


P2,, P22 


Port2bits1,and2, I/O 


51 


Vss 


Power Supply Ground 


52-56 


P23-P2, 


Port 2 bits 3 thru 7, I/O 


57-64 


PWM.g-PWMg 


Pulse Width Modulator Output 



PIN FUNCTIONS 



fiifC^. AFC Analog Voltage, (input). Input to two compara- 
tors used for AFC voltage analog to digital conversion. The 
comparator outputs are internally connected to PQ^j for 
the Z86C27. They are external outputs for the Z86C97 
ROM-less part. 

AS. Address Strobe -Z86C97(ou{\:)uX). External addresses 
and R/W status are valid at the trailing edge of this strobe. 

DS. Data Strobe - Z56C97 (output). Read and write data 
transactions are controlled by this strobe. 



^sYNc- Horizontal Sync (mpuV). HgYNc is an input pin supply- 
ing an externally generated Horizontal Sync signal of either 
negative or positive polarity. 

OSC,„, OSCoy^- ^'^^^ Oscillator (input/output). These 
pins connect to the internal video dot clock L-C oscillator 
circuit. 

PO^-PO^. High Address Bus - Z86C97 (output). The ROM- 
less device uses this port to output the high order address 
('^8-15) during an external memory cycle. 
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Pl^-Ply. Multiplexed Address/Data Bus - Z86C97. The 
ROM-less device uses this port to multiplex Jow order 
address (A^.^ during AS) and data (D^^.^ during DS) for an 
external memory cycle. 

P20-P27. Porf 2(input/output). This 8 bit general purpose 
port is bit programmable for either input or output. The 
output drivers (for bits defined as outputs) are globally 
programmable as either push-pull or open-drain. 

PSp. Porf 3 £?/Y0 (input). This input may be read directly. A 
negative edge event will be latched in IRQ3 to initiate an 
IRQ3 vectored interrupt If appropriately enabled. P3q going 
high will also initiate a STOP mode recovery if the device 
is stopped. 

P3^. Port 3 bit 1 (input). This input may be read directly. A 
negative edge event will be latched in IRQg to initiate an 
IRQ2 vectored interrupt if appropriately enabled. It can 
also be programmed to serve as the T,^ signal to Timer 1 . 

P3^, P3g. Port 3 bits 4 and 5 (outputs). These pins are 
general purpose output bits. 

P3g. Port 3 bit 6 (output). P3g may be used as a general 
purpose output bit or may be programmed to output T^^ 
(from Timer 1 or Timer 2) or S^lk. 

P4^,-P4^. Port 4 - Z86C27(output). Port 4 is an 8-bit output 
port. 

PS^j-PS^. Port 5 - Z86C27 (output). Port 5 is an 8-bit output 
port with a higher current sink capability - suited for driving 
the cathodes of a multiplexed LED display. 

Pe^j-PGg. Port 6 -Z86C27 only (m^uX). Port 6 is a 6-bit input 
port. Bits 6 and 7 are internally connected to the outputs of 
the AFC comparators. 

P6g, P67. AFC Comparator Outputs - Z86C97 only. These 
pins serve as outputs for the internal comparators used in 
the AFC,^ analog to digital converter. They may be con- 
nected to bits 6 and 7 of an external Port 6 emulation port 
if required. 



PWM,. UbitPWM (output). PWM^ istheoutputof a 14-bit 
resolution Pulse Width Modulator or may be programmed 
as a general purpose output. In either case, the output 
driver is a 1 2 volt open-drain . PWM 1 is typically used as the 
D to A converter for Voltage Synthesis Tuning systems. 

PWM2-PWM3. 6-bit PWM's {outputs). Pins PWMg^ are out- 
puts of 6-bit resolution Pulse Width Modulator circuits. 

PWM,-PWM,3. 8-bit PWM's (outputs). Pins PWM9.^3 ^^^ 
outputs of 8-bit resolution Pulse Width Modulator circuits or 
may be individually programmed as general purpose 
outputs. In either case, the output drivers are 1 2 volt open- 
drain. 

R/W. Read/Write Status - Z86C97 (output). A low level 
signifies an external memory write cycle. 



RESET. System Reset. A low level on RESET forces a cold 
restart of the device. 

^BLANK- ^^deo Blank (output). Output of the Blank video 
signal. May be programmed for either polarity. 

VpLUE- WcyeoS/ae (Output). Outputofthe Blue video signal. 
May be programmed for either polarity. 

Vcc, Vss. Power and Ground. Care must be taken to 
adequately bypass the supplied voltage at the device 
power pins. Two bypass capacitors of . I^^p each are recom- 
mended - one on each side of the device located as close 
as possible to the pins. 

^GREEN- ^^deo Green (output). Output of the Green video 
signal. May be programmed for either polarity. 

^RED- ^'^^o Red (output). Output of the Red video signal. 
May be programmed for either polarity. 

^sYNc- ^^^'^^^ ^y^^ (i^nput). VgYN^ is an input pin supplying 
an externally generated Vertical Sync signal of either 
negative or positive polarity. 

XTAL,, XTALj. Osc///ator (input and output). These pins 
connect to the internal clock oscillator circuit. XTAL^ may 
also be used as an external clock input. 
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XTAL1 
XTAL2 
RESET 



P30 
P31 
P34 
P35 
P36 
P40( P10 
P41(P11 
P42(P12 
P43( P13 
P44(P14 
P45(P15 
P46(P16 
P47( P17 
P50{P00 
P51(P01 
P52(P02 
P53(P03 
P54(P04 
P55( P05 
P56(P06 
P57(P07 
P60(AS 
P61(DS 
P62(R/W 
P63(SCLK 
P64( P66 
P65(P67 
AFCIN 



RESET 

Oscillator 

WDT 



Counter 
Timer 



Counter 
Timer 



Port 3/ 
Interrupt 



<^ 



Port4 
(Porti) 



^ 



Ports 
(PortO) 



Port 6 
(Control) 



^ 



^ 



8KByte 
Program ROM 



Z8CPU 
Core 



IE 

IT 




256 Byte 
Register File 



^g ^r 



Port 



Porti 



^>A8:15 <>AD0:7 



V 



160 Byte 
Character RAM 



V 



4KByte 
Ctiaracter ROM 



PWM1 
14 bit 



PWM2 

to 
PWM8 

6 bit 



PWM9 

to 

PWM13 

8 bit 



-► PWM1 

-^ PWM2 
-^ PWM3 
-*^ PWM4 
-^ PWM5 
-► PWM6 
-^ PWM7 
-► PWM8 
-► PWM9 
-^ PWM10 
-► PWM11 
-► PWM 12 
-*- PWM 13 



On Screen 
Display 



■ OSCIN 
OSCOIH" 

■ HSYNC 
• VSYNC 

VRED 
VGREEN 
VBLUE 
VBLANK 



Figure 3. Z86C27 (Z86C97) Block Diagram 
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INPUT/OUTPUT CrRCUITS 

Mapping Symbolic Pad Types 
to Pin Functions 



Pin Name 


Pad Type 


Note 


XTAL^, OSC,^ 


1 




XTALg. OSGq^ 




High gain start, 
low gain run 




8 


amplifier circuit 


RESET 




POo-PO, 


6 


Z86C97only 


P1o-P^7 


4 


Z86C97 only 


P2o-P2, 


5 




P3o-P3, 


2 




P34-P36 


3 




PVP4, 


3 


Z86C27 only 


P5o-P5, 


3 


Z86C27 only 


P60-P65 


2 


Z86C27 only 


P6,-P6, 

AS, DS, R/W, SCLK 


3 


Z86C97 only 


3 


Z86C97 only 


AFC,^ 


9 




PWM^-PWM,3 


7 




H V 
'sync ^sync 

V V 

"RED' "blue- 

V V 

^ GREEN' ^ BLANK 


2 
3 









VDD 



^^ 20 Ohm 




Figure 5. Input only, Schmidt Triggered 
(Pad Type 2) 



VDD 



OUT 




PAD 

n 



Figure 6. Output only (Pad Type 3) 



VDD 



<1 



-AA/V 




Figure 4. Input only (Pad Type 1) 



VDD 



OUT 



h>fiO 



< 




Figure 7. Input/Output 3-state (Pad Type 4) 
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VDD 



Figure 8. Input/Output, 3-state, Open Drain 
(Pad Type 5) 



RPU 



RESET 



-4 



20 Ohm PAD 

AAA/-n 



rm 



VDD 



OEN 



OUT 




b>dOH 



PAD 

u 



Figure 11. Reset input Circuit (Pad Type 8) 



VDD 



Figure 9. Output only, 3-state (Pad Type 6) 



VDD 



OUT 



-|>Ht^ 




PAD 




20 Ohm PAD 

i VVV^' — D 



A 

rm 



Figure 12. AFC Input Circuit (Pad Type 9) 



rm 



Figure 10. Output only, 12 volt Open Drain 
(Pad Type 7) 
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ABSOLUTE MAXIMUM RATINGS 



Absolute Maximum Ratings 



Parameter @ T.=25°C 



Sym 



Min 



Max 



Power supply voltage 


Vno 


-0.3V 


+7V 


Input voltage 


V, 


-0.3V 


Vcc +0.3V 


Input voltage 


V 
1(1) 


-0.3V 


Vcc +0.3V 


Output Voltage 


^0(2) 


-0.3V 


Vcc+8V 


Output current high, 1 pin 


"m 


- 


-10mA 


Output current high, all total 


"m 


- 


-100mA 


Output current low, 1 pin 


'n 


- 


10mA 


Output current low, 1 pin 


'oL{3) 


- 


20mA 


Output current low, all total 


'r. 


- 


200mA 


Operating temperature 




-o°c 


+70°C 


Storage temperature 




-65°C 


+150^0 


Power Dissipation 




~ 


2.2W 
(Ta=70°C) 



Comment: Exposing the device to stresses above those 
listed in Absolute Maximum Ratings could cause perma- 
nent damage. Exposure to absolute maximum rating 
conditions for extended periods of time may effect device 
reliability. 

Note: 

(1) Port 2 open drain 

(2) PWM open drain outputs 

(3) Port 5 



STANDARD TEST CONDITIONS 

Characteristics listed below apply for standard test condi- 
tions as noted. 



Variance of Vg, R^^^ ^"^ ^lh 






Output Circuit Vg 


Rlu 


^LH 


Standard CMOS output +5V 
Port 4 high current output +5V 
PWM 1 2 volt open drain output + 1 2V 


IK 
.5K 
4K4 


2K 
2K 



From (Xitput 
Under Test <^ 



^ 



:150pf 



Figure 13. Standard Output Test Load 



CAPACITANCE 



TA=25«C, V =GND=OV, f=1.0MHz, 
Unmeasureo pins to GND. 



Parameter 



Max 



Input capacitance 
Output capacitance 
I/O capacitance 
AFC,^ input capacitance 



lOpF 
20pF 
25pF 
10pF 
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DC CHARACTERISTICS 



TA=0*»C to +70*»C; V^.=+4.5V to +5.5V; F™=4inHz 



Parameter 



Sym 



Min 



Typ 



Max 



Condition 



Input voltage low 
Input voltage high 
Reset input current 
Schmidt Hysteresis 



v.. 



.7V.. 



.1V., 



■2Vcc 






V 






^cc 






-80mA 


V= 


=ov 


TBD 


Vr.= 


:.4V 


TBD 


v^ = 


:.4V 


TBD 


VoL= 


:.4V 



Output current low 



AFC Level 01 In 
AFC Level 11 In 
AFC Tracking 



OL(1) 

^(XM)1 
^01-11 

V -V 



11 



0.75mA 

3.2mA 

1mA 

•3Vco 

•5Vcc 



2mA 
4mA 

1.5. 






Output current high 
Min. supply voltage 
I np. leakage current 
Tri-state leakage 
Supply current 



'MIN 



TBD 

-3mA 
-IOmA 



-2mA 



2mA 



TBD 


Vc^=V^-.4V 


2.5V 




3HA 


O.Vec 


lOpA 


o.v,c 


20mA 




3mA 




lOjiA 





Note: 

(1) Port 5 , 

(2) PWM Open Drain 
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AC CHARACTERISTICS ( Z86C27 and Z86C97) 



TA=OX to 70^C; Vcc=+4-5 V to +5.5V; F™=4MHz, Units In nS 



No 



Sym 



Parameter 



Min 



Max 



TpC 
TrC.TfC 

TwC 
TwTinL 
TwTinH 



Input clock period 
Clock input rise and fall 
Input clock width 
Timer input low width 
Timer input high width 



250 

70nS 

70nS 

100 



1000ns 
15nS 



6 TpTin Timer input period 

7 TrTin.TfTin Timer input rise and fall 
8A TwIL Int req input low (P31 ) 
8B TwIL Int req input low (P30) 
9 TwIH Int request input high 



8TpC 

70nS 
3TpC 
3TpC 



lOOnS 



10 
11 
12 
13 
14 



TdpoR 

' ^LVIRES 

TWres 
TdHsOl 
TdHsOh 



Power On Reset delay 25mS 

Low voltage detect to Internal RESET condition 200nS 

Reset minimum width 5TpC 

•^sYNc start to Vqsc stop 2TpV 
HsYNc end to V^^ start 



lOOmS 



3TpV 
ITpV 



Notes: 

1 . Refer to DC Characteristics for details on switching levels. 



AC TIMING DIAGRAM (Z86C27 and Z86C97) 



XTAL1 




Figurie 14. External Clock 



IRQn 




Figure 16. Interrupt Request 



Tin 







*<iH 




Figure 15. Counter Timer 
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Vcc 



Internal RESET 



External RESET 



-^ 



® 



/ \J\ 



y \y 



Figure 17. Power On Reset 



HSYNC 



0SC2 




Figure 18. On Screen Display 
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AC CHARACTERISTICS UNIQUE TO Z86C97 



TA=OoC to 70oC; VCC=+4.5 Vto +5.5V; F0SC=4mHz 



No 



Sym 



Parameter 



Min 



Max 



' ^AS{AS) 
'^AS{DR) 
TW.o 



Td 



AZPS) 



Address valid to AS delay 
AS high to Address float delay 
AS high to Read Data required 
AS low width 
Addr float to DS low 



35 
45 

55 
5 



220 



6 
7 
8 
9 
10 



Td, 
Th. 



Td. 



DSR{DR) 
'dR{DS) 



DS(A) 



DS Read low width 
DS Write low width 
DS low to Read Data req'd 
Read Data to DS high hold 
DS high to Address active 



185 
110 

5 
55 



130 



11 
12 
13 
14 
15 



J^DS{AS) 
' ^R/W(AS) 
'^DS{R/W) 

' ^DW(DSW) 
' ^DS(DW) 



DShIgh to AS low delay 
R/W valid to AS high delay 
DS high to R/W not valid 
Write Data valid to DS low 
DS high to Write Data not valid 



55 
35 
55 
35 
55 



16 



Td 



'A(DR) 



Address valid to Read Data 
required valid 



330 



17 
18 



Td 
Td, 



^AS(DS) 
DI(DS) 



AS high to DS low delay 
Data Input setup to DS high 



65 
75 



Notes: 

1. When using extended menrxDry timing, for parameters 3, 6, 7, 8, 16 and 18 add 2TpC (500 nS @ 4.0 MHz). 

2. Min and Max times are in nanoseconds unless othen/yise noted. 
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TIMING DIAGRAM (Unique to Z86C97) 



SCLK 
XTAL1 



PORTO 
R/W 



P0RT1 



AS 



DS 

READ 



P0RT1 



DS 

WRITE 



-n- 



T2 H^- T3 H 



X 



X 



X 



*<!2>* 



*<i> *<!>* 



/ 



-©- 



A0-A7 



®- 



D0-D7 in 






(?>* 



*-<2H-^L / 



XA0-A7 V 



DO-D7 0ut 



k<5>- 



-ay-] 



\_y 



\ 



i*s* 



K 



-® 



Figure 19. Z86C97 External Memory Read/Write Timing 
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STANDARD CHARACTER SETS 

ENGUSH/KOREAN 





MSD 


LSD 


1 1 1 2 1 3 1 4 1 5 1 6 1 7 





1 

2 
3 
4 
5 
6 
7 
8 
9 
A 
B 

C 
D 

E 
F 



Bi 



BiB 



X 



m 



A 



^ 



tH 



II 



i 



KHOH 

Z3~ 



I 



I 



m 






iOf 



E 



UK 



m 



B 







a 



Dl 



BJaUK 



o 



iBOE 



)K 







Pf 



1 



aiBS 



3CS 



iomi 



6FU 



7GIU 



QJ 



01 



3 



Sie 



I 



M 



N 



m 




s 



s 



JZ 



BiB 



Da 







E 



i 






7) 



5 



n 



ix 
o 



o 



a 



a 



^j 



Figure 20. English/Korean 



REGISTER SUMMARY 

Refer to the Z8 Technical Manual for standard Z8 register 
and port descriptions. Registers shown here are specific 
to the Z86C27/97. 

Port Registers 



Port 4 



FC30h 



Output Control 

Logic Level 

1 Logic Level 1 



TTTTTTTT 

Figure 21. Port 4 Output Register 



Ports 










FC31h 


E 


6 


5 


4 


3 


2 


i|o| 



TTTTTTTT 



Output Control 

Logic Level 

1 Logic Level 1 



Figure 22. Port 5 Output Register 



Porte FC32h 


II 


6|6|4|3|2ll|0| 




— T T T TT T 



Port 6 Input 

Logic Level 

1 Logic Level 1 
AFC Output 

00 GND thru VI 

01 VI thru V2 
11 V2thruVcc 



Figure 23.. Port 6 input Register 



PWM Registers 



%FC10 



PWM f^ODE 



B 



TTTTTTTT 

8 7 6 5 4 3 2 1 



Mode Control 
OPWM 
1 Output Port 



Figure 24. PWIVi IVIode Register 



%FC11 








PWM OUT 


E 


6 


5 


4 


3 


2 


1 


^ 
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Figure 25. PWI\/I Port Output Register 
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Figure 28. P'WM2Value 
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Figure 29. PWM 3 Value 
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Figure 30. PWI\/l4Value 
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Figure 33. PiVIW7Value 
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Figure 34. PWM 8 Value 
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Figure 35. PWM 9 Value 
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Figure 36. PWM 10 Value 
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Figure 37. PWM 11 Value 
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Figure 31. PWM 5 Value 

%FC18 PWM6VAL 

] 



PWM6 Value 



Figure 32. PWM 6 Value 
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Figure 38. PWM 12 Value 
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Figure 39. PWM 13 Value Register 
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OSD Registers 



OSDC CNTRL 



FCOOh 
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High Resolution Sel 
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Figure 40. OSD Control Register 
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Figure 41 . OSD Vertical Postion Register 
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Figure 44. OSD Row Space Register 

FADE PCS FC05h 



Vertical Index 



Figure 45. OSD Fade Position Register 
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Figure 46. OSD Bar Control Register 
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Figure 42. OSD Horizontal Position Register 
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Figure 43. OSD Display Attribute Register 
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Figure 47. OSD Bar Position Register 
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ORDERING INFORMATION 


Part Number 


Package 


ROM 


Z86C2708PSCRXXX 
Z86C2708PSCRXXX 
Z86C9708PSCR314 


64-Pin DIP 
64-Pin DIP 
64-Pin DIP 


Custom mask-ROM , . 
Evaluation mask-ROM 
Korean/English Char Gen 
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Preliminary Product Specification 



May 1989 



Z86C27EAB 

Emulation Adapter Board 



FEATURES 

■ Z86C9708PSC 8 MHz ROM-less device. 

■ 27C64/27C256 EPROM ZIF socket. 

■ Full Port 4, Port 5 and Port 6 functional emulation. 

■ ICE support with third party analyzer-emulator available 
from Orion Instruments. 



On-board CPU Crystal and Video L-C oscillator circuits- 
jumper selectable. 

Z86C27 mask-ROM footprint or cable interface to target 
system. 



DESCRIPTION 

The Z86C27EAB Emulation Adapter Board is specifically 
designed to assist in the development of software for 
Zilog's Z86C27 mask-ROM Digital Television Controller. 

The board utilizes a Z86C97 ROM-less (^evice that pro- 
vides an address and data path (for access to external 
memory and I/O) and additional emulation signals. As the 
Z86C97 uses Port 4, Port 5 and Port 6 for the external inter- 
face, the emulation board simulates true Z86C27 port 
functions with additional on-board logic (Figure 1). 



An EPROM socket is provided to allow validation of 1 
customer ROM-code before submitting to Zilog for ge 
eration of the Z86C27 ROM mask. 

in-Circuit Emulation with real time trace capability is sup 
ported in conjunction with a "Unilab™" 8620 or 8420 ana- 
lyzer-emulator available separately from Orion Instruments. 
Orion is located at: 702 Marshall Street, Redwood City, CA 
94063 (Ph: 415/361-8883. FAX: 415/361-8970). 




To Orion 

"Analyzer" 

Connector 



To 

"Emulator" 
Connector 



Figure 1. Z86C27EAB Block Diagram 
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PIN ASSIGNMENTS 

Target Z86C27 Interface 

The Z86C27 EAB can plug directly into the target socket or 
may be connected via ribbon cable to the target if access 
Is difficult. Connectors P1 and P2 are used for the ribbon 
cable interface or as test points (Table 1). The supplied 
Cable Adapter has a corresponding P1 and P2 - do not 
reverse the P1 and P2 assignments. 

A ribbon cable connection will degrade signal integrity, so 
the length of cable should be kept as short as possible. The 
local crystal and L-C oscillator components mounted on 
the Emulation Adapter Board should always be used If a 
ribbon cable connection is selected. 

Note that GND and VCC are both connected to the target 
interface. Power the EAB board locally if the target system 
can not supply sufficient current. 



ORION Emulation Interface 

Connectors P3 and P4 have signals allocated to allow a 
direct connection to the ORION analyzer/emulator (Table 
2). Connector P3 connects to the "Emulator" connector 
and P4 to the "Analyzer" connector on the ORION. Use the 
appropriate cables supplied by ORION. 



Miscellaneous Connectors/Jumpers/Test 
Points 

P5 connects to power and may be used for power supply 
connection if the target supply is not used. J1 and J2 allow 
isolation of the target oscillator circuits. J3 provides test 
points for the address decodes of videoram and the 
simulated I/O ports (Table 3). 



Table 1. Z86C27 Interface - Pi, P2 



P1 


Target Z86C2 


P2 


Target Z86C27 




SIGNAL 


PIN 




SIGNAL 


PIN 


1 


PWM5 


1 


1 


PWM6 


64 


2 


PWM4 


2 


2 


PWM7 


63 


3 


PWM3 


3 


3 


PWM8 


62 


4 


PWM2 


4 


4 


PWM9 


61 


5 


PWM1 


5 


5 


PWM10 


60 


6 


P35 / 


6 


6 


PWM11 


59 


7 


P36 * 


7 


7 


PWM12 


58 


8 


P34 


8 


8 


PWM13 


57 


9 


P31 


9 


9 


P27 


56 


10 


P30 


10 


10 


P26 


55 


11 


XTALI^ 


11 


11 


P25 


54 


12 


XTAL2^ 


12 


12 


P24 


53 


13 


RESET 


13 


13 


P23 


52 


14 


P60 


14 


14.15 


GND 


51 


15,16 


GND 


15 


16 


P22 


50 


17 


P61 


16 


17 


P21 


49 


18 


P62 


17 


18.19 


VCC 


, 48 


19.20 


VCC 


18 


20 


P20 


47 


21 


P63 


19 


21 


P47 


46 


22 


P64, 


20 


22 


P46 


45 


23 


P65 


21 


23 


P45 


44 


24 


AFCIN 


22 


24 


P44 


43 


25 


P50 


23 


25 


P43 


42 


26 


P51 


24 


26 


P42 


41 


27 


P52 


25 


27 


.P41 


40 


28 


P53 


26 


28 


P40 


39 


29 


P54 


27 


29 


VBLANK 


38 


30 


P55 


28 


30 


VBLUE 


37 


31 


P56 


29 


31 


VGREEN 


36 


32 


P57 


30 


32 


VRED 


35 


33 


0SCIN2 


31 


33 


VSYNC 


34 


34 


0SC0UT2 


32 


34 


HSYNC 


33 



Notes: 

1 . XTAL1 and XTAL2 are connected to P1 via jumper block J2 pins 1-2 
and 3-4. Leave these jumpers open for local crystal operation. 

2. OSCIN and OSCOUT are connected to P1 via jumper block J 1 pins 1- 
2 and 3-4. Leave these jumpers open for local L-C operation. 
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Table 2. ORION Interface - P3, P4 



Table 3. Misc. Connectors/Jumpers/Test Points 



EABP3 
Pin Sig 



Orion "Ennui" 
Pin Sig 



EABP4 
Pin Sig 



Orion "Anal" 
Pin Sig 



Pin 



Signal 



Comment 



A14 

A12 

A13 

A7 

A8 



A14E 

A12E 

A13E 

A7E 

A8E 



P27 
P26 
P25 
P24 
P23 



M7 
M6 
IV15 
IV14 
iV13 



6 A6 


6 


A6E 


6 


P22 


6 W\2 


7 A9 


7 


A9E 


7 


P21 


7 Ml 


8 A5 


8 


A5E 


8 


P20 


8 IVIO 


9 A11 


9 


A11E 


9 


GND 


9 GND 


10 A4 


10 


A4E 


10 


RESET 


16 RES 


11 DS 


11 


OE 


11 


_ 


17 NiVli 


12 A3 


12 


A3E 


12 


GND 


18 GND 


13 A10 


13 


A10E 


13 


- 


19 K2 


14 A2 


14 


A2E 


14 


R/W 


20 07 


15 ROMCS 


15 


CE 


15 


- 


21 K1 


16 A1 


16 


A1E 


16 


_ 


22 06 


17 AO 


17 


AOE 


17 


DS 


23 WR 


18 GND 


18 


GND 


18 


- 


24 05 


19 AD7 


19 


D7E 


19 


- 


25 RD 


20 AD6 


20 


D6E 


20 


- 


26 04 


21 ADO 


21 


DOE 


21 


A15 


27 A15 


22 ADS 


22 


D5E 


22 


- 


28 ALE 


23 AD1 


23 


DIE 


23 


P35 


NO- 


24 AD4 


24 


D4E 


24 


P36 


NO - 


25 AD2 


25 


D2E 


25 


P31 


NO- 


26 AD3 


26 


D3E 


26 


P30 


NO- 


27 INTP67 


43 


D15A 








28 INTP66 


44 


D14A 








29 P34 


45 


D8A 








30 - 


46 


D13A 








31 - 


47 


D9A 








32 - 


48 


D12A 








33 - 


49 


D10A 








34 - 


50 


D11A 









P5-1 GND Ground test point or supply 

P5-2 VOO VOO test point or supply 

J1-1,2 OSOIN Open isolates OSOIN from target 

J1-3,4 OSOOUT Open isolates OSOOUT from target 

J2-1,2 XTAL1 Open isolates XTAL1 from target 

J2-3.4 XTAL2 Open isolates XTAL1 from target 

J3-1 VRAM Test point for Videoram select signal 

J3-2 P6 Test point for port 6 select signal 

J3-3 P5 Test point for port 5 select signal 

J3-4 P4 Test point for port 4 select signal 



Unilab 8620/8420 Analyzer/Emulator Setup 

The standard Orion software is distributed to support 
eitfier piggy-back or ROM-less versions of generic Z8 
microcontroller products. Tfie system must be especially 
configured to support the Z86C27EAB development envi- 
ronment. 

1 . Follow Orion instructions for installation and invocation 
of standard Orion Z8 distribution software. 

2. Ohoose the external memory version of the Z8. 

3. From the main menu, press "F8" to select TOOLKIT 
ROUTINES. 

4. Press "F8" again to select CHANGE DISPLAY OR 
LOG MODES. 

5. Set the window settings as shown: 



Disassembler 


on 


Symbols 


off 


Reset 


enabled 


Misc Oolumn 


on 


Oont Oolumn 


on 


Misc # Ba?e 


binary 


Paginate 


on 


Oolor 


on (if color display) 


Log to File 


off 


Printer 


off 


Step-into 


software 


Debug 


active i 
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a Type "EM-SET" [RETURN]. This command is used 
for memory configuration. 

7. Enable memory 0-37FF in "EIV1SEGF." Press "END" 
key to save and exit. 

8. Type "INTDATA" [RETURN]. This command 
configures the stack to be internal. 

9. Type "EXTRAM" [RETURN]. This command 
configures the RAM to be external. 

10. Type "PTR =D0" [RETURN]. This command sets the 
Orion Debug registers to DOh and D1 h of the Z8 register 
file. The user program must not use these registers. 



1 1 . Type "2001 =OVERLAY" [RETURN]. This command 
sets the Orion debug overlay area to start at address 
2001 h. 

12. Type "8000 =READ" [RETURN]. This sets the 
external RAM pointer to address 8000h. 

13. Type "SAVE-SYS C27EAB" [RETURN]. This saves 
a new system called C27EAB. 

14. Type "BYE" [RETURN] to exit from the Orion 
environment. 

Now that the system is saved, to re-invoke the Orion 
software with the parameters that have been just set-up, 
type C27EAB. 
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Figure 2. Z86C27EAB Layout 
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ELECTRICAL CHARACTERISTICS 



ORDERING INFORMATION 



Refer to seperate data sheets for individual AC and DC 
characteristlcsof tfieZ86C9708PSC, Z86C2708PSC, user 
EPROM and Altera™ EP1 81 OJ EPLD. Particular considera- 
tion should be given to characteristic differences between 
the Z86C27 and the EAB board with respect to ports 4, 5 
and 6. 

Parameters listed in Table 4 are supplemental to the indi- 
vidual device parameters or apply to the EAB as a whole. 



Part Number Comment 



Z86C2708EAB Includes Z86C9708PSC ROM-less 
device (Korean/English character 
generator ROM). 



Table 4. Supplemental Parameters 



Parameter 



Sym Min Max Condition 



Power supply voltage 


Vcc 


4.8v 


5.2v 




Power supply current 


«cc 


- 


100mA 




Input voltage low 


v,,^ 





.8v 




Input voltage high 


V.H^ 


2.0 


VCC 




Output current high 


•m^ 


-4mA, 


- 


VaH=2.4v 


Output current low 


'c^ 


4mA 


- 


V^=.45v 


Output current max 


U,^ 


- 




±20mA 


Operating Temp 




10°C 


50°C 





Notes: 

1 , These parameters apply to Port 4, 6 and 6 and differ from the Z86C27 
implementation. 
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Product Specification 



January 1989 



Z86C91CM0S 

ROMleisn IS® Microcomputer 



FEATURES 



Complete microcomputer, 24 I/O lines, and up to 64K 
bytes of addressable external space each for program 
and data mentory. 

256-byte register file, including 236 general-purpose 
registers, 8 i/O port registers, and 16 status and control 
registers. 

Vectored, priority interrupts for I/O, counter/timers, and 
UART. 

On-chip oscillator that accepts crystal or external clock 
drive. 



Full-duplex UART and two programmable 8-bit 
counter/timers, each with a 6-bit programmable 
prescaler. 

Register Pointer so that short, fast instructions can 
access any one of the sixteen working-register groups. 

Single + 5V power supply— all I/O pins TTL compatible. 

12, 16, and 20 MHz 

CMOS process 

Two Low-power Standby Modes 



GENERAL DESCRIPTION 



The Z86C91 is a CMOS ROMIess version of the Z8 single- 
chip microcomputer. It offers all the outstanding features of 
the Z8 family architecture except an on-chip program 



ROM. Use of extemal memory rather than a prepro- 
grammed ROM enables this Z8 microcomputer to lie used 
in applications where code flexibility is required. 



TIMING 

AND 

CONTROL 



PORTO 

(NIBBLE 
PROGRAMMABLE) 

I/O OR Ag-Ais 



PORT 1 

(BYTE 
PROGRAMMABLE) 

AD0-AD7 



— ^ 


RESET +5V 
R/W GNO 
DS XTAL1 
AS XTAL2 
POo P2o 
PO, P2i 

PO2 P22 
PO3 P23 
PO4 P24 

PO5 Z86C91 P25 
POg MCU P26 

POr P27 
PI0 P3o 
PI1 P3i 
PI2 P32 

PI3 P33 
PI4 P34 
PI5 P35 
Pie P36 

PI 7 P37 














^ 




















* 








* 




* 




* 












* 







PORT 2 

(BIT PRO- 
GRAMMABLE) 

I/O 



PORTS 

SERIAL AND 
PARALLEL I/O 
AND CONTROL 



+ 5V 


c 


1 


40 


3P36 


XTAL2 


c 


2 


39 


3p3, 


XTAL1 


L 


3 


38 


]P27 


P37 


c 


4 


37 


3P2e 


P3o 


c 


5 


36 


3p2s 


RESET 


L 


6 


35 


3P24 


R/W 


L 


7 


34 


3p23 


DS 


L 


8 


33 


Dp2. 


AS 


L 


9 


32 


3P2. 


P35 

GND 




10 Z86C91 31 

11 "«^" 30 


3p2o 
3P33 


P32 


L 


12 


29 


3P34 


POo 


L 


13 


28 


3PI7 


PO1 


C 


14 


27 


3 Pie 


PO2 


C 


15 


26 


3 Pis 


PO3 


L 


16 


25 


3PI4 


PO4 


L 


17 


24 


3PI3 


PO5 


L 


18 


23 


3P1a 


POe 


C 


19 


22 


3pii 


PO7 


C 


20 


21 


3P10 



Figure 1. Pin Functions 



Figure 2a. 40-pin Dual-ln-Llne Package (DIP), 
Pin Assignments 
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The Z86C91 can provide up to 16 output address lines, tlius 
pernnitting an address space of up to 64K bytes of data or 
program memory. Eight address outputs (AD0-AD7) are 
provided by a multiplexed, 8-bit, Address/Data bus. The 
remaining 8 bits can be provided by the software 
configuration of Port to output address bits As-A-i 5. 

Available address space can be doubled (up to 1 28K bytes) 
by programmingbit 4 of Port 3 (P34) t o act as a data memory 
select output (DM). The two states of DM together with the 
16 address outputs can define separate data and memory 
address spaces of up to 64K bytes each. 



There are 256 bytes of RAM located on-chip and organized 
as a register file of 236 general-purpose registers, 1 6 control 
and status registers, and three I/O port registers. This 
register file can be divided into sixteen groups of 16 working 
registers each. Configuring the register file in this manner 
allows the use of short format instructions; in addition, any of 
the individual registers can be accessed directly. 

The, pin functions and the pin assignments of the Z86C91 
package are illustrated in Figures 1 and 2. 
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Figure 3. Functional Biocic Diagram 
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ARCHITECTURE 

Architecture is characterized by a flexible I/O scheme, an 
efficient register and address space structure and a number 
of ancillary features that are helpful in many applications. 

Microcomputer applications demand powerful I/O 
capabilities. The Z86C91 fulfills this with 24 pins available for 
input and output. These lines are grouped into three ports of 
eight lines each and are configurable under software control 
to provide timing, status signals, serial or parallel I/O with or 
without handshake, and an address bus for interfacing 
external memory. 

Three basic address spaces are available: program memory, 
data memory and the register file (internal). The 256-byte 



random-access register file is composed of 236 
general-purpose registers, three I/O port registers, and 16 
control and status registers. 

To unburden the program from coping with real-time 
problems such as serial data communication and 
counting/timing, an asynchronous receiver/transmitter 
(DART) and two counter/timers with a large number of 
user-selectable modes are offered on-chip. Hardware 
support for the UART is minimized because one of the 
on-chip timers supplies the bit rate. Figure 3 shows the block 
diagram. 



LOW POWER STANDBY MODES 



The Z86C91 has two instructions to reduce power 
consumption during standby operation. HALT turns off the 
processor and UART while the counter/timers and external 
interrupts IRQO, IRQ1, and IRQ2 remain active. 

When an interrupt occurs the processor resumes execution 
after servicing the interrupt. STOP turns off the clock to the 
entire Z86C91 and reduces, the standby current to 10 
microamps. The stop mode is terminated by reset, which 
causes the processor to restart the application program at 
adddress OOOCH. In order to enter STOP or HALT modes, 



it is necessary to first flush the instruction pipeline to avoid 
suspending execution mid-instruction. To do this, the user 
must execute a NOP (opcode=OFFH) Immediately before 
the appropriate sleep instruction, ie 

FF NOP ; clear the pipeline 
6F STOP ; enter STOP mode 

or 
FF NOP ; clear the pipeline 
7F HALT ; enter HALT mode 



PIN DESCRIPTION 



AS. Address Strobe (output, active Low). Address Strobe is 
pulsed once at the beginning of each machine cycle. 
Addresses output via Port 1 for all external program or data 
memory transfers are valid at the trailing edge of AS. 

DS. Data Strobe (output, active Low). Data Strobe is 
activated once for each external memory transfer. For a 
READ operation, data must be available prior to the trailing 
edge of DS. For WRITE operations, the falling edge of DS 
indicates that output data is valid. 

POo-P07, P2o-P27, P3o-P37. I/O Port Lines (input/outputs, 
TTL-compatible). These 24 lines are divided into three 8-bit 
I/O ports that can be configured under program control for 
I/O or external memory interface (Figure 3). 

PIq-PIz- Address/Data Port (bidirectional). Multiplexed 



address (A0-A7) and data (D0-D7) lines used to interface with 
program and data memory. 



RESET. Reset (input, active Low). RESET initializes the 
Z86C91 . Aft er RESE T the MCU is in the extended memory 
mode. When RESET is deactivated, program execution 
begins from program location OOOCh- 

R/W goes low foi- the duration of a WRITE operation to 
Program or Data memory. 

XTAL1 , XTAL2. Crystal 1 , Crystal 2 (time-based input and 
output, respectively). These pins connect a parallel-reso- 
nant crystal, LC circuit, or ceramic resonator to the on-chip 
oscilator and buffer. A single-ended TTL or CMOS clock is 
also valid at the XTAL1 input. 



ADDRESS SPACES 

Program Memory. The Z86C91 addresses 64K bytes of 
external program memory space (Figure 4). 

The first 12 bytes of program memory are reserved for the 
interrupt vectors. These locations contain six 16-bit vectors 
that correspond to the six available interrupts. Program 
execution begins at location OOOCh after a reset. 

Data Memory. The Z86C91 can address 64K bytes of 
external data memory. External data memory may be 



included with or separated from the external program 
memory space. DM, an optional I/O signal that can be 
programmed to appear on pin PS^, is used to distinguish 
between data and program memory space. The state of the 
DM signal is controlled by the type instruction being exe- 
cuted. An "LDC" opcode references PROGRAM (DM inac- 
tive) memory, and an "LDE" instruction references DATA 
(DM active low) memory. 
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Register File. The 256-byte register file includes three I/O 
port registers (PO, P2, P3), 236 general-purpose registers 

(R4-R239) and 16 control and status registers (R240-R255). 
These registers are assigned the address locations shown in 
Figure 5. 

Z86C91 instructions can access registers directly or 
indirectly with an 8-bit address field. This also allows short 
4-bit register addressing using the Register Pointer (one of 
the control registers). In the 4-blt mode, the register file is 
divided into sixteen working-register groups, each 
occupying 16 contiguous locations (Figure 5). The Register 
Pointer addresses the starting location of the active 
working-register group (Figure 6). 

Note: Register Bank EO-EF can only be accessed through 
working register and indirect addressing modes. 

Stacks. Either the internal register file or the external data 
memory can be used for the stack. A 16-bit Stack Pointer 
(R254 and R255) is used for the external stack, which can 
reside anywhere in data memory. An 8-blt Stack Pointer 
(R255) is used for the internal stack that resides within the 
236 general-purpose registers (R4-R239). For internal 
stack, R256 may be used as a general-purpose register, 
however its contents will be impacted in the event of a stack 
overflow. 



CATION OF FIRST 
BYTE OF INSTRUCTION 
EXECUTED AFTER "" 
RESET 



INTERRUPT 
VECTOR^ 
(LOWER BYTE) 



INTERRUPT 
VECTOR^ 
(UPPER BYTE) 



PROGRAM 
MEMORY 


DATA 
MEMORY 


— IRQ5 


IRQ4 


IR03 


— IRQ2 


— IRQ1 


— IRQO 



Figure 4. Z86C91 Program Memory Map 



DECIMAL 
255 
254 
253 
252 
251 
250 
249 
248 
247 
246 
245 
244 
243 
242 
241 
240 



STACK POINTER (BITS 7-0) 



STACK POINTER (BITS 15-8) 



REGISTER POINTER 



PROGRAM CONTROL FLAGS 



INTERRUPT MASK REGISTER 



INTERRUPT REQUEST REGISTER 



INTERRUPT PRIORITY REGISTER 



PORTS 0-1 MODE 



PORT 3 MODE 



TO PRESCALER 



TIMER/COUNTER 



T1 PRESCALER 



TIMER/COUNTER 1 



TIMER MODE 



GENERAL-PURPOSE 
REGISTERS 



HEX 


IDENTIFIERS 


FF 


SPL 


FE 


SPH 


FD 


RP 


FC 


FLAGS 


FB 


IMR 


FA 


IRQ 


F9 


IPR 


F8 


P01M 


F7 


P3M 


F6 


P2M 


F5 


PREO 


F4 


TO 


F3 


PRE1 


F2 


T1 


F1 


TMR 


FO 


SIO 


EF 





P3 
P2 



Figure 5. The Register File 



255 
253 



THE UPPER NIBBLE OF THE REGISTER 
FILE ADDRESS PROVIDED BY THE 
REGISTER POINTER SPECIFIES THE 
ACTIVE WORKING-REGISTER GROUP. 



SPECIFIED WORKING- 
REGISTER GROUP 



THE LOWER 
NIBBLE OF 
THE REGISTER 
FILE ADDRESS 
PROVIDED BY 
THE INSTRUCTION 
POINTS TO THE 
SPECIFIED 
REGISTER. 



Figure 6. The Register Pointer 
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SERIAL INPUT/OUTPUT 



Port 3 lines P3q and PS^ can be programmed as serial I/O 
lines for full-duplex serial asynchronous receiver/transmit- 
ter operation. The bit rate is controlled by Counter/Tlmer 0, 
with a maximum rate of 1 56.25K bits/second at 20 MHz. 

The Z86C91 automatically adds a start bit and two stop bits 
to transmitted data (Figure 7). Odd parity is also available as 
an option. Eight data bits are always transmitted, regardless 



of parity selection. If parity is enabled, the eighth data bit is 
used as the odd parity bit. An interrupt request (IRQ4) is 
generated on all transmitted characters. 

Received data must have a start bit, eight data bits, and at 
least one stop bit. If parity is on, bit 7 of the received data is 
replaced by a. parity error flag. Received characters 
generate the IRQ3 interrupt request. 



SPlDrlDslDslD. 



D3|D;|d,|Do|st] 

L 



START BIT 
EIGHT DATA BITS 
TWO STOP BITS 



I SP I D7 I De I Ds I D4 



D3 I D2 I Di I DqIst] 



L 



START BIT 
EIGHT DATA BITS 
ONE STOP BIT 



Transmitted Data 
(No Parity) 



Received Data 
(No Parity) 



SP IP De D5] D4 I D3 I D2 I Di I Dp ST 



-START BIT 
-SEVEN DATA BITS 
-ODD PARITY 
-TWO STOP BITS 



|sp|p|d6|d5|d4|d3|d2|Di|do|st| 

L 



START BIT 
SEVEN DATA BITS 
PARITY ERROR FLAG 
ONE STOP BIT 



Transmitted Data 
(With Parity) 



Received Data 
(Witli Parity) 



Figure 7. Serial Data Formats 



COUNTERmMERS 



The Z86C91 contains two 8-bit programmable 
counter/timers (Tq and Ti), each driven by its own 6-bit 
programmable prescaler. The Ti prescaler can be driven by 
internal or external clock sources; however, the Tq prescaler 
is driven by the internal clock only. 

The 6-bit prescalers can divide the input frequency of the 
clock source by any number from 1 to 64. Each prescaler 
drives its counter, which decrements the value (1 to 256) that 
has been loaded into the counter. When the counter reaches 
the end of count, a timer interrupt request — IRQ4 (Tq) or 
IRQ5 (Ti)— is generated. 

The counters can be started, stopped, restarted to continue, 
or restarted from the initial value. The counters can also be 
programmed to stop upon reaching zero (single-pass mode) 



or to automatically reload the initial value and continue 
counting (modulo-n continuous mode). The counters, but not 
the prescalers, can be read any time without disturbing their 
value or count mode. 

The clock source for T^ is user-definable ; It can be either the 
internal microprocessor clock divided by four, or an exter- 
nal signal input via Port 3. The maximum frequency of the 
external Timer signal is the XTAL signal divkied by 8. The 
Timer Mode register configures the external timer input as 
an external dock, a trigger input that can be retriggerable 
or nonretriggerable, or as a gate input for the internal clock 
The counter/timers can be programmably cascaded by 
connecting the T,, output to the input of T^. Port 3 line P3g 
also serves as a timer output (T^y^.) through which T,,, T^ or 
the internal clock can be output. 



I/O PORTS 



The Z86C91 has 24 lines available for input and output. 
These lines are grouped into three ports of eight lines each 
and are configurable as input, output or address. Under 
software control, the ports can be programmed to provide 



address outputs, timing, status signals, serial I/O, and 
parallel I/O with or without handshake. All ports have active 
pull-ups and pull-downs compatible with TTL loads. 
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Port 1 is a dedicated Z-BUS® compatible memory 
interface. The operations of Port 1 are supported by tlie 
Address Strobe (AS)^and Data Strobe (DS) lines, and by 
the Read/Write (R/W) and Data Memory (DM) control 
lines. The low-order program and data memory addresses 
(A0-A7) are output through Port 1 (Figure 8) and are 
multiplexed with data in/out (Do'-Dy). Instruction fetch and 
data memory read/write operations are done through this 
port. 



(^ 



Z86C91 
MCU 



PORT1 

(I/O OR AD0-AD7) 



TO EXTERNAL 
MEMORY 



Port 1 cannot be used as a register nor can a handshake 
mode be used with this port. 

The Z86C91 wakes up with the 8 bits of Port 1 configured 
as address outputs for external memory. If more than eight 
address lines are required, additional lines can be 
obtained by programming Port bits as address bits. The 
least-significant four bits of Port can be configured to 
supply address bits As-A-i 1 for 4K byte addressing or both 
nibbles of Port can be configured to supply address bits 
As-Ai5 for 64K byte addressing. 

^^Tl> C^ 



PAD 

-a 



J>— ^ 



Figure 8a. Port 1 



Figure 8b. Simplified Port 1 Output Configuration 



Port can be programmed as a nibble I/O port, or as an 
address port for interfacing external memory (Figure 9). 
When used as an I/O port, Port can be placed under 
handshake control. In this configuration, Port 3 lines P32 
and P35 are used as the handshake controls DAVq and 
RDYq. Handshake signal assignment is dictated by the I/O 
direction of the upper nibble PO4-PO7. 

For external memory references. Port can provide 
address bits As-An (lower nibble) or A8-A15 (lower and 
upper nibbles) depending on the required address space. 
If the address range requires 12 bits or less, the upper 



nibble of Port can be programmed independently as I/O 
while the lower nibble is used for addressing. 

Port lines are configured as address lines A8-A15 after a 
Reset. If one or both nibbles are needed for I/O operation, 
they must be configured by writing to the Port Mode 
register. 

To permit the use of slow memory, an automatic wait mode 
of two oscillator clock cycles is configured for bus timing 
after each reset. The initialization routine could include 
reconfiguration to eliminate this extended timing mode. 



t4i, 



P04rP07 I PORTO 
28eC»1 A K fP00-P03 f(l/OORA8-A,5) 



^ HAND SHAKE CONTROLS 
> DAVo AND RDYo 
' (P32 AND PSg) 



Figure 9a. Port 



V ggr 



-o- 



3> 



t^^ 




PAD 



Auto Latch 

Figure 9b. Simpiified Port I/O Configuration 
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Port 2 bits can be programmed independently as input or 
output (Figure 10), Tiiis port is always available for I/O 
operations. In addition, Port 2 can be configured to 
provide open-drain outputs. 

Like Port 0, Porf 2 may also be placed under handshake 





^ ^ 


P20 










J-L 


PORT 2(1/0) 


Z86C91 
MCU 










P27 




► , 


HANDSHAKE CONTROLS 
DAV2 AND RDY2 
(P3i AND PSe) 



Figure 10a. Port 2 



control. In this configuration, Port 3 lines P3i and PSe are 
used as the handshake controls lines DAV2 and RDY2. 
The handshake signal assignment for Port 3 lines P3i and 
P36 is dictated by the direction (input or output) assigned 
to bit 7 of Port 2. 



OPEN DRAIN 



^oiN 



k:)— q^ 




L^<i-«<1^ 



Auto Latch 

Figure 10b. Simplified Port 2 I/O Configuration 



Port 3 lines can be configured as I/O or control lines 
(Figure 11 ). In either case, the direction of the eight lines is 
fixed as four input (P3o-P33) and four output (P34-P37). For 
serial I/O, lines P3o and PSy are programmed as serial in 
and serial out, respectively. 



Port 3 can also provide the follo wing control functions: 
handshake for Ports and 2 (DAV and RDY); four external 
interrupt request signals (IRQ0-IRQ3); timer input and 
output signals (T|n and Tqut) and Data Memory Select 
(DM). 



PORT 3 

(I/O OR CONTROL) 



Figure 11a. Port 3 



D- 



4-t>— ><4l 



■^ 



Figure lib. Simpiified Port 3 Input Configuration 



INTERRUPTS 



The Z86C91 allows six different interrupts from eight 
sources: the four Port 3 fines P3o-P33, Serial In, Serial Out, 
and the two counter/timers. These interrupts are both 
maskable and prioritized. The Interrupt Mask register 
globally or individually enables or disables the six interrupt 
requests. When more than one interrupt is pending, priorities 
are resolved by a programmable priority encoder that is 
controlled by the Interrupt Priority register. 

All interrupts are vectored through locations in program 
memory When an interrupt request is granted, an interrupt 
machine cyde is entered. This disables all subsequent 
interrupts, saves the Program Gountei^ and status flags, and 
accesses the program memory vector location reserved for 
that interrupt. This memory location and the next byte 
contain the 16-bit address of the interrupt service routine for 
tiiat particular interrupt request. Nested interrupts are 



supported by enabling intemjpts In the interrupt service 
routine. 

Polled interrupt systems are also supported. To 
accommodate a polled structure, any or all of the interrupt 
inputs can be masked and the Interrupt Request register 
polled to determine which of the interrupt requests needs 
service. Software Initiated interrupts are supported by 
setting the apppropriate bit in the Intenrupt Request Regis- 
ter (IRQ-register 250, OFAH). 

Internal interrupt requests are sampled on the falling edge 
of the last cycle of every instruction. Externally generated 
interrupt requests (input to Port 3) are delayed by a 5 TpC 
filter, so in order to be valid at an intermpt sample point, the 
Interrupt request must be valid 5TpC before the falling edge 
of the last clock cycle of the currently executing instruction. 



185 



When the Z86C91 samples a valid interrupt request, the 
next 48 (external) clock cycles are used to prioritize the 
Interrupt, and push the two PC bytes and the FLAGS 
register on the stack. The following 9 cycles are used to 
fetch the Interrupt vector from external memory. The first 



byte of the Inten-upt service routine Is fetched beginning on 
the 58th TpC cycle following the Intemal sample point, 
which corresponds to the 63rd TpC cycle following the 
extemal intentjpt sample point. 



CLOCK 

The on-chip oscillator has a high-gain, parallel resonant 
amplifier for connection to a crystal, ceramic resonator, or 
resonant LC circuit. A CMOS or TTL level clock oscillator 
is also acceptable. Unlike its NMOS counterpart, the 
Z86C91 dock should be driven single-ended with the 
XTAL2 output left floating. 

A low level clock source (crystal, resonator, or parallel LC 
combination) should be connected across XTAL1 and 
XtAL2 with capacitor "legs" from each pin to ground. 
Table 1 shows recommended capacitor values for the 
oscillator qircuit in figure 12. 



Oscillator 
Type 



Cl (min) 



Cl (max) 



Crystal 


12pF 


60pF 


Ceramic 


12pF 


60pF 


Resonator 






LC Circuit 


33pF 


47pF 



Table 1 Recommended capacitor values for 
various types of oscillator circuits. 



)CTAL 

HDH 



28 
XTAL1 

XTAL2 



Figure 12. Z86C91 Oscillator Configuration 

CRYSTAL TYPE 

For a crystal clock input, the Z8 requires the following 
specificatioris: 

■ AT cut, parallel resonant 

■ Fundamental Type 

■ Series resistance, R^ ^ lOOQ 

■ Capacitance Cq<30pF 

■ Frequency 20MHz maximum 



RESET 

To avoid asynchronous and noisy RESET problems, the 
Z86C91 is equipped with a R ESET filt er of four external 
clocks (4TpC). If the external RESET signal is less than 
4TpC in duration, no RESET will occur. 

On the fifth clock after the RESET is detected, an internal 
RST signal is latched and held for an internal register count 
of 18 external clocks, or for the duration of the external 



RESET, whichever is longer. During the RESET cycle, DS 
is held active low while AS cycles at a rate of TpC/2. 

Program execution begins at location OOOC 5-10 TpC 
cycles after RST is released. 

For power-on RESET, the RESET time must be held low for 
50mS, or until Vcc Is stable, whichever is longer. 
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INSTRUCTION SET NOTATION 

Addressing^ Modes. The following notation is used to 
describe the addressing modes and instruction operations 
as shown in the instruction sumnnary. 

IRR Indirect register pair or indirect working-register 

pair address 

Irr Indirect working-register pair only 

X Indexed address 

DA Direct address 

RA Relative address 

IM Imnnediate 

R Register or working-register address 

r Working-register address only 

IR Indirect-register or indirect working-register 

address 

Ir Indirect working-register address only 

RR Register pair or working register pair address 

Symbols. The following symbols are used in describing the 
instruction set. 

dst Destination location or contents 

src Source location or contents 

cc Condition code (see list) 

@ Indirect address prefix 

SP Stack pointer (control registers 254-255) 

PC Program counter 

FLAGS Flag register (control register 252) 

RP Register pointer (control register 253) 

IMR Interrupt mask register (control register 251) 



Assignment of a value is indicated by the symbol "*-". For 
example, 

dst *- dst -f- src 

indicates that the source data is added to the destination 
data and the result is stored in the destination location. The 
notation "addr(n)" is used to refer to bit "n" of a given 
location. For example, 

dst (7) 

refers to bit 7 of the destination operand. 

Flags. Control Register R252 contains the following six 
flags: 

C 

z 
s 

V 
D 
H 



Carry flag 
Zero flag 
Sign flag 
Overflow flag 
Decimal-adjust flag 
Half-carry flag 

Affected flags are indicated by: 

Cleared to zero 

1 Set to one 

* Set or cleared according to operation 

— Unaffected 

X Undefined 



CONDITION CODES 



Value 



Mnemonic 



Meaning 



Flags Set 



1000 




Always true 




— 


0111 


C 


Carry 




C = 1 


1111 


NO 


No carry 




C = 


0110 


z 


Zero 




Z = 1 


1110 


NZ 


Not zero 




Z = 


1101 


PL 


Plus 




S = 


0101 


Ml 


Minus 




S = 1 


0100 


ov 


Overflow 




V = 1 


1100 


NOV 


No overflow 




v = o 


0110 


EQ 


Equal 




Z = 1 


1110 


NE 


Not equal 




z = o 


1001 


GE 


Greater than or equal 




(S XOR V) = 


0001 


LT 


Less than 




(SXORV) = 1 


1010 


GT 


Greater than 




[Z OR (8 XOR V)] = 


0010 


LE 


Less than or equal 




[ZOR(SXORV)] = 1 


1111 


UGE 


Unsigned greater than ( 


or equal 


C = 


0111 


ULT 


Unsigned less than 




C = 1 


1011 


UGT 


Unsigned greater than 




(C = OANDZ = 0)= 1 


0011 


ULE. 


Unsigned less than or equal 


(CORZ) = 1 , 


0000 




Never true 




— 
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CCF, Dl, El, IRET, NOP, 
RCF, RET, SCF 



dst I OPC~] INCr 

One-Byte instructions 



ORG MODE 



CLR, CPL, DA, DEC, 



Hcwcr^ no U i 1 n l rfc«/«r^ I DECW, INC, INCW, POP, 

dst/src OR |1 1 1 0|dst/src | pygH, RL, RLC, RR, 



dst/src OPC 



I OPC 



dst/CC I OPC 



OR |1 1 1 ol dsT 



OPC 


MODE 


dst 


src 



MODE 


OPC 


dst/src 


src/dst 



RRC, SRA, SWAP 
JP, CALL (Indirect) 



ADC, ADD, AND, 
CP, OR, SBC, SUB, 
TCM, TM, XOR 



LD, LDE, LDEI, 
LDC, LDCI 



OR 1 1 1 src 



OPC 


1 MODE 1 


src 


dst 



MODE I OPC 



DAl 



DAl 



1110 


src 


1110 


dst 



OR |l 1 1 0| dsT" 



MODE 


OPC 


dst/src 


X 


ADDRESS 1 



ADC, ADD, AND, CP, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 



ADC, ADD, AND, CP, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 



1110 


src 


1110 


dst 



Two-Byte Instructions 



Three-Byte Instructions 



Figure 13. Instruction Formats 



INSTRUCTION 


SUMMARY 




Instruction 
and Operation 


AddrlVlode 
dst src 


Opcode 
Byte 
(Hex) 


Fiags Affected 
C Z S V D H 


ADCdst.src 

dst *- dst + src + C 


(Note1) 


in 


It ft * it it 


ADDdst.src 
dst *- dst + src 


(Note1) 


on 


it it it * it 


ANDdst.src 

dst -^ dst AND src 


(Notel) 


5n 


-it it 


CALL dst 

SP*-SP - 2 
@SP*-PC;PC^ds1 


DA 
IRR 


D6 
D4 




CCF 

C^NOTC 




EF 


* 


CLRdst 

dst*-0 


R 
IR 


BO 
B1 




COIMdst 

dst ^ NOT dst 


R 
IR 


60 
61 


— * * 


CP dst.src 
dst - src 


(Notel) 


AD 


* * * * 



PA dst 

dst — DA dst 



R 
IR 



40 * * * X 
41 



Instruction 
and Operation 


AddrMode 

\ 

dst src 


Opcode 
Byte 
(Hex) 


Flags Affected 
C Z S V D H 


DECdst 

dst*- dst - 1 


R 
IR 




00 
01 


— * * * 


DECW dst 

dst — dst - 1 


RR 
IR 




80 
81 


^ it * it 


Dl 

IMR(7)*-0 






8F 





DJNZr.dst 

r-r - 1 
ifr#.0 

PC-PG + dst 
Range: +127, -128 



El 

IMR(7)*-1 



HALT 



INC dst 

dst — dst + 1 



RA rA 

r = 0- F 

9F 

7F 

r rE — it it it 

r = - F 
R 20 

IR 21 



INCW dst 

dst -dst + 1 



RR 
IR 



AO 
A1 



it it it 
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INSTRUCTION SUMMARY (Continued) 





AddrlVlode 


Opcode 


Fiags Affected 


Instruction 




Byte 




and Operation 


dst src 


(Hex) 


C Z S V D H 


IRET 




. BF 


it it ft it * it 


FLAGS *-@SP;SP^SP + 1 






PC*-@SP;SP* 


-SP + 2;IMR(7) 


*-1 




JPccdst 


DA 


cD 




if cc is true 




c = 0- F 




PC ^ dst 


IRR 


30 





JR cc.dst 


RA 




cB 


if cc is true, 






c = 0- F 


PC*- PC + dst 








Range: +127,-128 








LD dst.src 


r 


Im 


rC — -^ 


dst ^ src 


r 


R 


r8 




R 


r 


r9 
r = 0- F 




r 


X 


C7 




X 


r 


D7 




r 


Ir 


E3 




ir 


r 


F3 




R 


R 


E4 




R 


IR 


E5 




R 


IM 


E6 




IR 


IM 


E7 




IR 


R 


F5 



LDC dst.src 
dst ^ src 



r 
Irr 



Irr 

r 



C2 
D2 



LDCi dst.src 


Ir 


Irr 


C3 


dst "*- src 


Irr 


Ir 


D3 


r ^ r + 1 ; rr ^ rr + 
1 









LDE dst.src 
dst ^ src 




r 
Irr 


Irr 
r 


82 
92 




LDEI dst.src 

dst *- src 

r *«- r + 1 ; rr ♦- rr 


+ 1 


Ir 
Irr 


Irr 
Ir 


83 
93 




NOP 








FF 




OR dst.src 

dst '^ dst OR src 




(Notel) 


4n 


— * * 


POPdst 

dst ^ @SP; 
SP-SP + 1 




R 
IR 




50 
51 


' 


PUSH src 

SP*-SP- 1;@SP*- 


src 


R 
IR 


70 
71 




RCF 

C-0 








CF 


: 


RET 

PC*-@SP;SP^ 


•SP + 2 




AF 








R 
IR 




90 
91 




RL dsi 1 


. 1 


* * * * 


B-HEI 


_ojJ 





instruction 
and Operation 


AddriViode 
dst src 


Opcode 
Byte 
(Hex) 


Fiags Affected 
Z S V D H 






10 
11 




«LCdst[g:_^ 


3jr. 


* * * * 






EO 
El 




"«dsl l^ l^^ 


^^R 


* * * * 










CO 
01 




""Cdst^^^j^ 


i^H. 


it it it it 


SBC dst.src 

dst ^ dst ^ src ^C 


(Notel) 


3n 


it it it it ^ it 


SCF 

C*-1 




&P 


1 






DO 
D1 




SRAdstC^ 


■^IR 


* * * 


I 1 1 




SRP src 

RP ^ src 


Im 


31 




STOP 




6F 




SUB dst.src 
dst -*- dst ^ src 


(Notel) 


2n 


* * * * 1 it 


SWAPdst i 1 


1 ID 


FO 
F1 


X it it X 


1 ^ 


1 In 




TCiy/l dst.src 
(NOT dst) AND src 


(Note 1) 


en 


— * * 


TIVI dst.src 
dst AND src 


(Notel) 


7n 


— * * 


XOR dst.src 
dst*- dst XOR src 


(Notel) 


BD 


-* * 



NOTE:. These instructions have an identical set of addressing nnodes, 
which are encoded for brevity. The first opcode nibble is found in 
the instruction set table above. The second nibble is expressed 
symbolically by a D in this table, and its value is found in the 
following table to the left of the applicable addressing mode pair. 
For example, the opcode of an ADC instruction using the 
addressing modes r (destination) and Ir (source) is 13. 



Addr i\/lode 



dst 


src 


r 


r 


■ r 


Ir 


R 


R 


R 


IR 


R 


IM 


IR 


IM 



ijower 
Opcode Nibble 
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REGISTERS 



R240 SIO 
Serial I/O Register 

(FOh. Read/Write) 

I D^j Del Dsj D4I D3J Dzj Di j Dp | 



-SERIAL DATA (Do = LSB) 



R244 TO 
Counter/Timer Register 

(F4h; Read/Write) 

I D7 [ Ds I D5 [ D4 [ D3 I D; I D, I Dp"] 



To INITIAL VALUE (WHEN WRITTEN) 

-(RANGE: 1 256 DECIMAL 01 00 HEX) 

To CURRENT VALUE (WHEN READ) 



R241 TMR 
Time Mode Register 

(F1h; Read/Write) 



R245 PREO 
Prescaler Register 

(F5h; Write Only) 



|T7 Dg 



Tout MODES 

NOT USED = 00 

To OUT = 01 ■ 

T, OUT = 10 

INTERNAL CLOCK OUT = 11 

Tin MODES 
EXTERNAL CLOCK INPUT = 00 
GATE INPUT = 01 
TRIGGER INPUT = 10 ■ 
(NONRETRIGGERABLE) 

TRIGGER INPUT = 11 
(RETRIGGERABLE) 



D4 D3 D2 D, Do 



333 



COUNT MODE 
- = To SINGLE-PASS 
1 = To MODULON 



-RESERVED (MUST BE 0) 



PRESCALER MODULO 
-(RANGE: 1-64 DECIMAL 
01-00 HEX) 



R242 T1 
Counter Timer 1 Register 

(F,2h; Read/Write) 

I D; [ De I D5 I D4 I D3 I D; I Di I Dp I 



R246 P2M 
Port 2 Mode Register 

(F6h; Write Only) 

I D, I De I D5 I D4 I D3 I D2 I Pj I d7| 



T, INITIAL VALUE (WHEN WRITTEN) 

-(RANGE 1 256 DECIMAL 01 00 HEX) 

T, CURRENT VALUE (WHEN READ) 



P2o-P27 I/O DEFINITION 
- DEFINES BIT AS OUTPUT 
1 DEFINES BIT AS INPUT 



R243 PRE1 
Prescaler 1 Register 

(F3h; Write Only) 



I D7 [ De I D5 



D4 I D3 I D; I D, I Dp I 



L 



COUNT MODE 

T, MODULON 
= T, SINGLE-PASS 

CLOCK SOURCE 
_ 1 T, INTERNAL 
T, EXTERNAL 



PRESCALER MODULO 
-(RANGE 1-64 DECIMAL 
01-00 HEX) 



R247 P3M 
Port 3 Mode Register 

(F7h; Write Only) 



I D7 DejDs I D4 D3 I D; I Di I D, 



Lo 



-RESERVED (MUST BE 0) 



P33 = INPUT 
"l J } P33 = INPUT 

1 1 RESERVED 



P34 = 
P34 = 



OUTPUT 
5Ri 



Figure 14. Control Registers 
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R248 P01M 
Port Mode Register 

(F8h; Write Only) 



I D,[Dg| D5JD4JD3I D;| D, [D( 



PO4-PO7 MODE 
OUTPUT = 00 
INPUT = 01 
A,j-A,5 = 1X 

EXTERNAL 
MEMORY TIMING - 
-NORMAL = 
'EXTENDED = 1 



POg-PO] MODE 

00 = OUTPUT 

01 = INPUT 
1X = Aj-A,, 

STACK SELECTION 
- = EXTERNAL 
1 = INTERNAL 



- RESERVED (MUST B 



R252 FLAGS 
Flag Register 

{FCh: Read/Write) 

d/ Ds [ D5 j D4 I D3 ! D; j D, I Dp I 

L, 



\1: 



USER FLAG F1 
USER FLAG F2 
HALF CARRY FLAG 
DECIMAL ADJUST FLAG 
OVERFLOW FLAG 
SIGN FLAG 
ZERO FLAG 
CARRY FLAG 



•ALWAYS EXTENDED TIMING AFTER RESET 



R249 IPR 
Interrupt Priority Register 

(F9h; Write Only) 



I D, I Dg I D5 I D4 I D3 I D; I D, I Dp I 



IRQ3, IRQ5 PRIORITY (GROUP A) 

= IRQ5 > IRQ3 - 

1 = IRQ3 > IR05 

IRQO, IRQ2 PRIORITY (GROUP B) 

= IRQ2 > IRQO - 

1 = IRQO > IRQ2 

IRQ1, IRQ4 PRIORITY (GROUP C) 

= IRQ1 > IRQ4 - 

1 = IRQ4 > IRQ1 



R253 RP 
Register Pointer 

(FDh; Read/Write) 

I D7 1 Dg I O5 1 O4 1 D3 1 Da I P, I Dp i ' 



RESERVED =111 



R250 IRQ 
Interrupt Request Register 

(FAh; Read/Write) 



R254 SPH 
Stack Pointer 

(FEh; Read/Write) 



RESERVED (MUST BE 



I D, I Dg I D5 I D4 I D3 I D; I Di [dTI 



DjDg Dg D4 D3 dJd, Dp 



IRQO = P32 INPUT (Do = IRQO) 

IRQ1 = P33 INPUT 

IRQ2 = P3i INPUT 

IRQ3 = P3o INPUT, SERIAL INPUT 

IRQ4 = To, SERIAL OUTPUT 

IRQ5 = Ti 



STACK POINTER UPPER 
" BYTE (SP,-SP,5) 



R251 IMR 
Interrupt Mask Register 

(FBh; Read/Write) 

jo, jOgJDg |d4Id3[D;| d, [DqI 



R255 SPL 
Stack Pointer 

(FFH;.Read/Write) 

I D7 I Pg I Dg I D4 I D3 I D; I D^ [ Dp j 



-RESERVED (MUST BE 0) 
-1 ENABLES INTERRUPTS 



Figure14. Control Registers (Continued) 
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OPCODE MAP 



Lower Nibble (Hex) 
7 8 



65 


65 


65 


6,5 


10,5 


105 


10,5 


10,5 


6,5 


6.5 


12/10,5 


12/10.0 


65 


12/10 


6.5 




DEC 


DEC 


ADD 


ADD 


ADD 


ADD 


ADD 


ADD 


LD 


LD 


DJNZ 


JR 


LD 


JP 


INC 




Rl 


IRi 


n ''2 


ri Ir2 


R2.R1 


IR2.R1 


Rl IM 


IRl,IM 


ri,R2 


r2,Ri 


ri RA 


cc.RA 


ri.lM 


ccDA 


rl 




6,5 


65 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 
































RLC 


RLC 


ADC 


ADC 


ADC 


ADC 


ADC 


ADC 
































Ri 


IRi 


ri,r2 


ri,lr2 


R2.R1 


IR2.R1 


Rl,IM 


IRl,IM 
























. 








65- 


6,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 




INC 


INC 


SUB 


SUB 


SUB 


SUB 


SUB 


SUB 
































Rl 


IRi 


'ri.r2 


-ri,lr2 


R2.R1 


IR2,Ri 


Rl,IM 


iRl.lM 
































8,0 


6,1 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 




JP 


SRP 


SBC 


SBC 


SBC 


SBC 


SBC 


SBC 
































IRRl 


IM 


ri,r2 


ri,lr2 


R2.R1 


IR2.R1 


Rl,IM 


IRl,IM 
































8,5 


8,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 


DA 


DA 


OR 


OR 


OR 


OR 


OR 


OR 
































Rl 


IRi 


ri.r2 


ri.lr2 


R2.R1 


IR2,Ri 


Rl,IM 


IRl,IM 
































10,5 


10,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5" 




POP 


POP 


AND 


AND 


AND 


AND 


AND 


AND 
































Rl 


IRi 


ri,r2 


ri,lr2 


R2.R1 


IR2.R1 


Rl,IM 


IRl.lM 
































6,5 


6,5 


6,5 


6,5 


• 10,5 


10,5 


10,5 


10,5 


6,0 


COM 


COM 


TCM 


TCM 


TCM 


TCM 


TCM 


TCM 






























STOP 


Ri 


IRl 


ri,r2 


ri,lr2 


R2.R1 


IR2.R1 


Rl.lM 


IRl,IM 
































10/12,1 


12/14,1 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 


7,0 


PUSH 


PUSH 


TM 


TM 


TM 


TM 


TM 


TM 






























HALT 


R2 


IR2 


ri,r2 


ri,lr2 


R2.R1 


IR2.R1 


Rl,IM 


IRi.lM 




























■ 




10,5 


10,5 


12,0 


18,0 










6 1 ' 


DECW 


DECW 


LDE 


LDEI 






































Dl 


RRl 


IRi 


ri,lrr2 


Iri,lrr2 








































6,5 


6,5 


12,0 


18,0 










6 1 


RL 


RL 


LDE 


LDEI 






































El 


Rl 


IRi 


r2,lrri 


Ir2,lrri 








































10,5 


10,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 


14.0 ' 


INCW 


INCW 


CP 


CP 


CP 


CP 


CP 


CP 






























RET 


RRl 


IRi 


ri,r2 


ri,lr2 


R2.R1 


IR2,Ri 


Rl.lM 


IRl,IM 
































6,5 


6,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 


16.0 


CLR 


CLR 


XOR 


XOR 


XOR 


XOR 


XOR 


XOR 






























IRET 


Rl 


IRi 


ri,r2 


riJr2 


R2.R1 


IR2.R1 


Rl,IM 


IRi,IM 
































6,5 


6,5 


12,0 


18,0 








10,5 


65 


. RRC 


RRC 


LDC 


LDCI 








LD 






























RCF 


Rl 


IRi 


ri,lrr2 


Iri,lrr2 








ri,x,R2 
































6,5 


6,5 


12,0 


18,0 


20,0 




20,0 


10,5 


65 


SRA 


SRA 


LDC 


LDCI 


CALL* 




CALL 


LD 






























SCF 


Ri 


IRi 


r2.trri 


Ir2,lrri 


IRRl 




DA 


r2.x,Ri 
































6,5 


6.5 




6,5 


10,5 


10,5 


10,5 


10,5 


65 


RR 


RR 




LD 


LD 


LD 


LD 


LD 






























CCF 


Rl 


IR1 




ri,IR2 


R2.R1 


IR2.R1 


Rl,IM 


IRi,IM 
































8,5 


8,5 




6,5 




10,5 






6,0 


SWAP 


SWAP 




LD 




LD 


































NOP 


Ri 


IRi 




in.r2 




R2,iRi 






\ 


f 


^ 


r 


\ 


r 


) 


r 


1 


' 


\ 


r 


\ 


r 





Bytes per Instruction 



LOWER 
OPCODE 
NIBBLE 



EXECUTION 
CYCLES 



w 



PIPELINE 
CYCLES 



UPPER 

OPCODE - 

NIBBLE 



10,5 
CP 

R2.R1 



FIRST 
OPERAND 



A^ 



SECOND 
OPERAND 



Legend: 

R = 8-bit address 
r = 4-bit address 
Rl or ri = Dst address 
R2 or r2 = Src address 

Sequence: 

Opcode, First Operand, Second Operand 

NOTE: The blank areas are not defined. 



*2-byte instruction, fetch cycle appears as a 3-byte instruction 
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ABSOLUTE MAXIMUM RATINGS 



Voltages on all pins with respect 

toGND -0.3V to +7.0V 

Operating Ambient 

Temperature See Ordering Information 

Storage Temperature -65°Cto -i-150°C 



Stresses greater than those listed under Absolute Maximum Ratings may 
cause permanent damage to the device This is a stress rating only, 
operation of the device at any condition above those indicated in the 
operational sections of these specifications is not implied Exposure to 
absolute maximum rating conditions for extended periods may affect 
device reliability. 



STANDARD TEST CONDITIONS 

The DC characteristics listed below apply for the following 
standard test conditions, unless otherwise noted. All 
voltages are referenced to GND. Positive current flows into 
the referenced pin. 

Standard conditions are as follows: 

■ + 4.5V < Vcc < +5.5V 

■ GND = OV 



FROM OUTPUT , 
UNDER TEST * 



^SOpFi I^KQ 




■ 0°C<Ta< +70°Cfor S (Standard " 


rempera 


ture) 






Figure 12. Test Load 1 


DC CHARACTERISTICS 


Symbol Parameter 


Min 


Typ 


Max 


Unit 


Condition 



VcH 


Clock Input High Voltage 


3.8V 


Vol 


Clock Input Low Voltage 


-0.3 


V,H 


Input High Voltage 


2.0 


K 


Input Low Voltage 


-0.3 


Vrh 


Reset Input Low Voltage 


3.8 


V 


Reset Input Low Voltage 


-0.3 


VoH 


Output High Voltage 


2.4 


VoH 


Output High Voltage 


V^c-IOOmV 


Vol 


Output Low Voltage 




>,L 


Input Leakage 


-10 


'oL 


Output Leakage 


-10 


MR 


Reset Input Current 




'go 


Supply Current 




'001 


Halt Mode Current 




'o02 


Stop Mode Current 





Voo 
0.8 

Voo 
0.8 

V 

*co 

0.8 



0.4 
10 
10 
-80 



10 



V 
V 



V 

uA 

uA 

uA 

mA 

mA 

uA 



Driven by Extemal Clock Generator 
Driven by Extemal Clock Generator 



•oh = -2mA 
lo„ = -100uA 
'oL = 5mA 

V =0V V 

V = OV V > 
4.5V<Vco<5.5V,V„L=0V 

All outputs and I/O pins floating 
All inputs driven at rail 
Ail inputs driven at rail 
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Figure 13. External I/O or Memory Read/Write 



AC CHARACTERISTICS 

External I/O or Memory read and Write Timing 



Number Symbol 



Parameter 



12MHz 16MHz 20MHz 
Min Max Min Max Min Max Units 



Notes 



1 TdA(AS) Address Valid to AS IDelay 

2 TdAS(A) AS tlo Address Float Delay 

3 TdAS(DR) AStto Read Data Req'd Valid 

4 TwAS AS Low Width _ 

5 TdAZ(DS) Address Float to DS I 



35 25 20 ns 2,3,4 

45 35 25 ns 2,3,4 

250 180 150 ns 1,2,3,4 

55 40 30 ns 2,3,4 

ns 



6 


TwDSR 


DS (Read) Low Width 


185 135 105 


ns 


1,2,3,4 


7 


TwDSW 


DS (Write) Low Width 


110 80 65 


ns 


1,2,3,4 


8 


TdDSR(DR) 


DSIto Read Data Req'd Valid 


130 75 55 


ns 


1,2,3,4 


9 


ThDR{DS) 


Read Data to DStHold Time 





ns 


2,3,4 


10 


TdDS(A) 


DStlo Address Active Delay 


65 50 40 


ns 


2,3,4 



11 TdDS(AS) DStlo AS iDej^ 45 35 25 ns 2,3,4 

12 TdRW(AS) Ry^Valld_toAStDelay 33 25 20 ns 2,3,4 

13 TdDS(R/W) DSttoR/WNotValld_ 50 35 25 ns 2,3,4 

14 TdDW(DSW) Write Data Valid to DSI(Write) Delay 35 25 20 ns 2,3,4 

15 TdDS(DW) DStto Write Data Not Valid Delay 55 35 25 ns 2,3,4 



16 
17 
18 


TdA(DR) 

TdAS(DS) 

TdDI(DS) 


Address Valid to Read Data Req'd Valid 31 230 
AStto DSIDelay 65 45 35 
Data Input Setup to DS t 75 60 50 


180 


ns 
ns 
ns 


1,2,3,4 

2,3,4 

1,2,3,4 


19 


TdDM(AS) 


DMValidtoASIDelay 50 30 20 




ns 


2,3,4 



Notes 

1 . When using extended memory timing add 2TpC 

2. Timing numbers given are for minimum TpC 

3. See clock cycle dependent characteristics tab\e 

4. 20 MHz timing is preliminary and subject to change 



+ Test Load 1 

* All timing references use 2.0V for a 
logic "1 " and 0.8V for a logic "0" 
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-<1>- 



■<3)-^\ 



^-TW^iUW/"^ 




fCI^^^ 



Figure 14. Additional Timing 



AC CHARACTERISTICS 

Additional Tinning Table 



Number Symbol 



Parameter 



12 MHz 
Min Max 



16 MHz 
Min Max 



20 MHz 
Min Max 



Notes 



1 TpC Input Clock Period 83 1000 

2 TrC.TfC Clock Input Rise & Fall Times 15 

3 , TwC Input Clock Width 37 

4 TwTinL Timer Input Low Width 75 

5 TwTinH Timer Input High Width 3TpC 



62.5 1000 

10 
21 
75 
3TpC 



50 

15 
75 
3TpC 



1000 
10 



6 


TpTIn 


Timer Input Period 


8TpC 


8TpC 


8TpC 


2 


7 


TrTinJfTin 


Timer Input Rise and Fall Times 


100 


100 


100 


2 


8A 


TwIL 


Interrupt Request Input Low Time 


70 


70 


70 


2,4 


8B 


TwIL 


Interrupt Request Input Low Time 


3TpC 


3TpC 


3TpC 


2,5 


9 


TwIH 


Interrupt Request Input High Time 


3TpC 


3TpC 


3TpC 


2,3 



Notes: 

1 . Clock timing references use 3.8 V for a logic "1 " and 0.8 V for a logic "0" 

2. Timing references use 2.0 V for a logic "1 " and 0.8 V for a logic "0" 

3. Interrupt references request via Port 3 

4. Inten-upt request via Port 3 (P3^ - P33) 

5. Interrupt request via P30 

6. 20 MHz timing is preliminary and subject to change. 
Units in nanoseconds (ns) 
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-A « 



DAV 




Figure 15a. Input Handshake Timing 



DATA OUT 



..X^ 



DATA OUT VALID 



k J 



X 



k 8 >l < 9; > 



-.^ 



-55- 



NEXT DATA OUT VALID 



V 



K. 



t..J 



y^ DELAYED RDY 



Figure 15b. Output Handslialte Timing 



AC CHARACTERISTICS 

Handshal^e Timing 



Number Symbol 



Parameter 



12,16,20 MHz 
Min Max 



Notes (Data Direction) 



1 


TsDI(DAV) 


Data In Setup Time 







In 


2 


ThDI(DAV) 


Data In Hold Time 


145 




In 


3 


TwDAV 


Data Available Width 


110 




In 


4 


TdDAV(RDY) 


DAVIto RDYIDelay 




115 


In 


5 


TdDAV(RDY) 


DAV ttoRDYt Delay 




115 


In 


6 


TdRDY(DAV) 


RDYtto DAVIDelay 







In 


7 


TdDO(DAV) 


DataOuttoDAViDelay 


TpC 




Out 


8 


TdDAVd(RDY) 


DAVIto RDYIDelay 







Out 


9 


TdRDY(DAV) 


RDYitoDAVtDelay 




115 


Out 


10 


TwRDY 


RDY Width 


110 




Out 


11 


TdRDY(DAV) 


RDYtto DAVmelay 




115 


Out 
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CLOCK DEPENDENT AC CHARACTERISTICS 

External I/O or Memoiy Read and Write Timing 



Number 


Symbol 


Equation 


1 


TdA(AS) 


0.4TpC+0.32 


2 


TdAS(A) 


0.59TpC-3.25 


3 


TdAS(DR) 


2.83TpC+6.14 


4 


TwAS 


0.66TpC-1.65 


6 


TwDSR 


2.33TpC-10.56 


7 


TwDSW 


1.27TpC+1.67 


8 


• TdDSR(DR) 


1.97TpC-42.5 


<0 


TdDS(A) 


0.8TpC 


11 


TdDS{AS) 


0.59TpC-3.14 


12 


TdR/W(AS) 


0.4TpC 


13 


TdDS(R/W) 


0.8TpC-15 


14 


TdDW(DSW) 


0.4TpC 


15 


TdDS(DW) 


0.88TpC-19 


16 


TdA(DR) 


4TpC-20 


17 


TdAS(DS) 


0.91TpC-10.7 


18 


TsDI(DS) 


0.8TpC-10 


19 


TdDM(AS) 


0.9TpC-26.3 
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MEMDRY SPACE AND REGISTER 

ORGANIZATION 

Memory Space 

The Z8 can address tq) to 126K bytes of 
program and data memory separately from the on 
chip registers. The 16-bit program counter 
provides for 64K bytes of program memory, the 
first 2K bytes of which are internal to the 28. 
The remaining 62K bytes of program memory are 
located externally and can be iirolemented vdth 
ROM, EPRCM, or RAM. 

The 62K bytes of data memory are also loc- 
ated external to tne Z8 and begin with location 
2048. The two address spaces, program memory 
and data memoiy, are individual ly selected by 
the Data Memory Select output (3!) which is 
available from Port 3. 

The Program Memory Map and the Data Memory 
Map are shown in Figure 2. 

Program Memory Map Data Memory Map 





65535 

2048 
2047 

\ 

12 
11 
10 
9 
8 
7 


EXTERNAL 
ROM OR RAM 


6SS3S 

2048 
2047 




EXTERNAL 

DATA 
MEMORY 


LOCATION OF FIRST 
BYTE OF INSTRUCTION > 
EXECUTED AFTER RESET 


ON-CHIP 
ROM 




X 




IRQ5 




IROS 




IRQ4 




IRQ4 


INTERRUPT VECTOR 


IR03 


(LOWER BYTE)- 


iRQ3 




•-*. IR02 




.^ IRQ2 


INTERflUPT VECTOR ^ 
(UPPER BYTE) 


2 

1 



IR01 


NOT ADDRESSABLE 


IR01 




IRQO 




IRQO 



Figure 2 Program Memory Map And Data Memory Map 



line 4 of tne Port 3 (P34) to select between 
program and data memory for external memory oper- 
ations. 

Port is used to provide the additional 
address bits for external memory beyond the 
first 256 locations iq) to a full 16-bits of 
external memory address . It becomes inmediately 
obvious that the first 8 -bits of external memory 
address from Port 1 must be latched externally 
to the Z8 so that program or data may be trans- 
ferred over the same 8 lines during the external 
memory transaction machine cycle. The 7S^, 155", 
and R/W control lines simplify the required 
interface logic. Hie timing for external memory 
transactions is given in Figure 3. 

Registers 

The Z8 has 144 8 -bit registers including 
four Port registers CR0-R3), 124 general purpose 
registers (R4-R127), and 16 control and status 
register (R240-R255). The 144 registers are all 
located in the same 8-bit address space to allow 
any Z8 instruction to operate on them. The 124 
general purpose registers can function as accum- 
ulators, address pointers, or index registers. 
The registers are read when they are referenced 
as source registers, and written when they are 
referenced as destination registers. Registers 
may be addressed directly with an 8 -bit address, 
or indirectly through another register with an 
8-bit address, or with a 4-Dit address and Reg- 
ister Pointer. 

The entire 28 register space may be divided 
into 16 contiguous Working Register Areas, each 
having 16 registers. A control register, called 
the Register Pointer, may be loaded with the 
most significant nibble of a Working Register 
Area address . The Register Pointer provides for 
the selection of the WorKing Register Area, and 
allows registers within that area to be selected 
with a 4-bit address. 

The Z8 register organization is shown in 
Figure 4. 

Stacks 



External memory access is acconplished by 
the Z8 through its I/O Ports, when less than 
256 bytes of external memory are required. Port 
1 is programmed for the multiplexed address/data 
mode (.AD0-AD7J. In this configuration 8-bits of 
address and 8-bits of data are time multiplexed 
on the 8 I/O lines for memory transfers. Tne 
memory "nandshake" control lines are provided by 
tne Address Strobe (SS) , Data Strobe (DS) , and 
the Read/Write (R/W) pins on tne Z8. If program 
and data are included in the external memory 
space, the Data Memory Select (M) function may 
be programmed into the Port 3 Mode register. 
When this is done, the Wi signal is available on 



The Z8 provides for stack operations 
through the use of a stack pointer, and the 
stack may be located in the internal register 
space or in the external data memory space. The 
"stack selection" bit (D2) in the Port 0-1 Mode 
control register selects an internal or external 
stack. When the stack is located internally, 
register 255 contains an 8-bit stack pointer and 
register 254 is available as a general purpose 
register. If an external stack is used, register 
255 or registers 254 and 255 may be used as tne 
stack pointer depending on the anticipated 
"depth" of the stack. When registers 254 and 
255 are both used, the stack pointer is a fiill 
16-bits wide. The CALL, IRET, RET, PUSH, and 



200 



POP instructions are Z8 instructions vMch in- 
clude ijnplicit stack operations. 



I/O STRUCTURE 



Parallel I/O 



The Z8 microcomputer has 32 lines of I/O 
arranged as four 8-bit ports. All of the I/O 
ports are TTL compatible and are configurable as 
input, output, input/output, or address/data. 
The handshake control lines for Ports 0, 1, and 
2 are bits from Port 3 that have been programmed 
through a Mode control register, except for JS, 
IE, and R/W \yhich are available as separate Z8 
pins. The I/O ports are accessed as separate 
internal registers by tne Z8. Ports and 1 
share one Mode control register, and Ports 2 
and 3 each have a Mode control register for 
configuring the port. 

Port can be programmed to be an I/O port 
or as an address output port. More specifically 
Port can be configured to be an 8-bit I/O port, 
or a 4-bit address output port (A8-A11) for 
external memory and one 4 -bit I/O port, or an 
8-bit address output port (A8-A15) for external 
memory. 

Port 1 can be programned as an I/O port 
(with or without handshake) , or an address/data 
port (AD0-AD7) for interfacing with external 
memory. If Port 1 is programmed to be an add- 
ress/data port, it cannot be accessed as a reg- 
ister. 

Port 2 can be configured as individual 
input or output bits, and Port 3 can be program- 
med to be parallel I/O bits, and/or serial I/O 
bits, and/or handshake control lines for the 
other ports. Figure 5 shows the port Mode 
registers. 

The off chip expansion capability using 
Ports and 1 offers the added feature of being 
Z-Bus compatible. All Z-Bus conpatible peri- 
pheral chips that are available now, and will be 
available in the future, will interface directly 
with the Z8 multiplexed address/data bus. 

Serial I/O 



As memtioned in the last section. Port 3 
can be programmed to be a serial I/O port with 
bits and 7, the serial input and serial out- 
put lines respectively, Ihe serial I/O capabil- 
ity provides for full duplex asynchronous serial 
data at rates 15) to 62. 5K bits per second. The 
transmitted format is one start bit, eight data 
bits including odd parity (if parity is enab- 
led) , and two stop bits . The received data 
format is one start bit, eight data bits and at 
least one stop bit. If parity is enabled, the 
eighth data bit received (bit 7) is replaced by 



a parity error flag v^ich indicates a parity 
error if it is set to a ONE. 

Timer/Counte.r T« is the baud rate generator 
and runs at 16 times the serial data bit rate. 
The receiver is double duffered and an internal 
interrupt (IRQ3) is generated when a character 
is loaded into the receive buffer register. A 
different internal interrupt (IRQ4) is generated 
vAen a character is transmitted. 

COUNTER/TIMERS 

The Z8 has two 8 -bit programmable counter/ 
timers, each of which is driven by a program- 
mable 6-bit prescaler. The T, prescaler can be 
driven by internal or external clock sources, 
and the Tq prescaler is driven by the internal 
clock only. The two prescalers and the two 
counters are loaded through four control regis- 
ters (see Figure 4) and when a counter/timer 
reaches the "end of count" a timer interrupt is 
generated (IRQ4 for Tq, and IRQ5 for TJ. The 
counter/ timers can be programmed to stop upon 
reaching the end of count, or to reload and 
continue counting. Since either counter (one at 
a time) can have its output available external 
to the Z8 , and Counter/Timer T 1 can have an 
external input, the two counters can be cais- 
caded. 

Port 3 can be programmed to provide timer 
outputs for external time base generation or 
trigger pulses. 

INTERRUPT STRUCTURE 

The Z8 provides for six interrupts from 
eight different sources including four Port 3 
lines (P30-P33), serial in, serial out, and two 
counter/timers. These interrupts can be masked 
and prioritized using the Intemq)t Mask Regis- 
ter (register 251) and the Interrupt Priority 
Register (register 249). All interrupts can be 
disabled with the master interrt5)t enable bit 
in the Intem^Jt Mask Register. 

Each of the six intern:5)ts has a 16 -bit 
intem5)t vector that points to its internqjt 
service routine. These six 2-byte vectors are 
placed in the first twelve locations in the pro- 
gram memory space (see Figure 2) . 

When simultaneous interrupts occur for 
enabled interrupt sources, the Interrupt Prior- 
ity Register determines v^iich interrupt is ser- 
viced first. The priority is programmable in a 
way that Is described by Figure 6. 

When an interrt5)t is recognized by the Z8, 
all other internets are disabled, the program 
counter and program control flags are saved, and 
the program counter is loaded with the corres- 
ponding interrupt vector. Intemqjts must be 
re-enabled by the user iqpon entering the service 



201 



A Programmer's Guide to 
th6 ZS"^ Microcomputer 



<S^ZiIGG 



Application 
Note 



Doll Freund 



October 1980 



SECTION Introduction 

I The Z8 is the first microcomputer to offer 

both a highly integrated microcomputer on a 
single chip and a fully expandable micropro- 
cessor for I/O-and memory-intensive applica- 
tions. The Z8 has two timer/counters, a UART, 
2K bytes internal ROM, and a"144-byte inter- 
nal register file including 124 bytes of RAM, 
32 bits of I/O, and 16 control and status reg- 
isters. In addition, the Z8 can address up to 
124K bytes of external program and data 
memory, which can provide full, memory- 
mapped I/O capability. 



This application note describes the important 
features of the Z8, with software examples that 
illustrate its power and ease of use. It is 
divided into sections by topic; the reader need 
not read each section sequentially, but may 
skip around to the sections of current interest. 

It is assumed that the reader is familiar with 
the Z8 and its assembly language, as 
described in the following documents: 

■ Z8 Technical Manual (03-3047-02) 

■ Z8 PLZ/ ASM Assembly Language Program- 
ming Manual (03-3023-02) 



Accessing Register Memory 

The Z8 register space consists of four I/O 
ports, 16 control and status registers, and 124 
general-purpose registers. The general- 
purpose registers are RAM areas typically used 
for accumulators, pointers, and stack area. 
This section describes these registers and how 
they are used. Bit manipulation and stack 
operations affecting the register space are 
discussed in Sections 4 and 5, respectively. 

2.1 Registers and Register Pairs. The Z8 sup- 
ports 8-bit registers and 16-bit register pairs. 
A register pair consists of an even-numbered 
register concatenated with the next higher 
numbered register (%00 and %01, %02 and 
%03, ... %7E and %7F, %F0 and %F1, ... 
%FE and %FF). A register pair must be 
addressed by reference to the even-numbered 
register. For example, 

%F1 and %F2 is not a valid register pair; 
%F0 and %F1 is a valid register pair, 
addressed by reference to %F0. 

Register pairs may be incremented (INCW) 
and decremented (DECW) and are useful as 
pointers for accessing program and external 
data memory. Section 3 discusses the use of 
register pairs for this purpose. 



Any instruction which can reference or 
modify an 8-bit register can do so to any of the 
144 registers in the Z8, regardless of the 
inherent nature of that register. Thus, I/O 
■ports, control, status, and general-purpose 
registers may all be accessed and manipulated 
without the need for 'special-purpose instruc- 
tions. Similarly, instructions which reference 
or modify a 16-bit register pair can do so to 
any of the valid 72 register pairs. The only 
exceptions to this rule are: 

■ The DINZ (decrement and jump if non-zero) 
instruction may successfully operate on the 
general-purpose RAM registers (%04-%7F) 
only. 

■ Six control registers are write-only registers 
and therefore, may be modified' only by 
such instructions as LOAD, POP, and 
CLEAR. Instructions such as OR and AND 
require that the current contents of the 
operand be readable and therefore will not 
function properly on the write-only 
registers. These registers are the following: 
the timer/ counter prescaler registers PREO 
and PREl, the port mode registers POIM, 
P2M, and P3M, the interrupt priority- 
register IPR. 
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2. Accessing 2.2 Register Pointer. Within the register 
Register addressing modes provided by the Z8, a regis- 

Memory ter may be specified by its full 8- bit address 

(Continued) (0-%7F, %FO-%FF) or by a short 4-bit 
address. In the latter case, the register is 
viewed as one of 16 working registers with- 
in a working register group. Such a group 
must be aligned on a 16-byte boundary and is 
addressed by Register Pointer RP (%FD). As 
an example, assume the Register Pointer con- 
tains %70, thus pointing to the working reg- 
ister group from %70 to %7F. The LD instruc- 
tion may be used to initialize register %76 to 
an immediate value in one of two ways: 



LD %76,#1 



or 
LD R6,#l 



! 8-bit register address is given 
by instruction (3 byte instruc- 
tion)! 

! 4-bit working register address 
is given by instruction; 4-bit 
working register group 
address is given by Register 
Pointer (2 byte instruction)! 



The address calculation for the latter case 
is illustrated in Figure 1 . Notice that 4-bit 
working-register addressing offers code com- 
pactness and fast execution compared to its 
8-bit counterpart. 

To modify the contents of the Register 
Pointer, the Z8 provides the instruction 

SRP #value 

Execution of this instruction will load the 
upper four bits of the Register Pointer; the 
lower four bits are always set to zero. Although , 
a load instruction such as 

LD RP,#value 

could be used to perform the same function, 
SRP provides execution speed (six vs. ten 
cycles) and code space (two vs. three bytes) 
advantages over the LD instruction. The 
instruction 

SRP #%70 

is used to set the Register Pointer for the above 
example. 



HbQISTER : 
POIMTPP 1 O 


1 1 1 


^ 
















INSTRUCTION 
(LD R6,#1) 


EI 


1 


"h 


1 


"1 












REGISTER r„ 
ADDRESS L2-J 


1 1 1 1 


1 


.iJ 





Figure 1. Address Calculation Using the Register Pointer 



2.3 Context Switching. A typical function 
performed during an interrupt service routine 
is context switching. Context switching refers 
to the saving and subsequent restoring of the 
program counter, status, and registers of the 
interrupted task. During an interrupt machine 
cycle, the Z8 automatically saves the Program 
Counter and status flags on the stack. It is the 
responsibility of the interrupt service routine to 
preserve the register spacis. The recommended 
means to this end is to allocate a specific por- 
tion of the register file for use by the service 
routine. The service routine thus preserves the 
register space of the interrupted task by avoid- 
ing modification of registers not allocated as its 
own. The most efficient scheme with which to 
implement this function in the Z8 is to allocate 
a working register group (or portion thereof) to 
the interrupt service routine. In this way, the 
preservation of the interrupted task's registers 
is solely a matter of saving the Register Pointer 
on entry to the service routine, setting the 
Register Pointer to its own working register 
group, and restoring the Register Pointer prior 
to exiting the service routine. For example, 



assume such a t-egister allocation scheme has 
been implemented in which the interrupt ser- 
vice routine for IRQO may access only working 
register Group 4 (registers %40-%4F). The 
service routine for IRQO should be headed by 
the code sequence: 

PUSH RP {preserve Register Pointer of 

interrupted task! 
SRP #%40 ! address working register 

group 4! 

Before exiting, the service routine should 
execute the instruction 

POP RP 

to restore the Register Pointer to its entry 
value. 

It should be noted that the technique 
described above need not be restricted to 
interrupt service routines. Such a technique 
might prove efficient for use by a subroutine 
requiring intermediate registers to produce its 
outputs. In this way, the calling task can 
assume that its environment is intact upon 
return from the subroutine. 
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2. Accessing 2.4 Addressing Mode. The Z8 provides three 
Register , addressing modes for accessing the register 

Memory space: Direct Register, Indirect Register, and 

(Continued) Indexed. 

2.4.1 Direct Register Addressing. This 
addressing mode is used when the target regis- 
ter address is known at assembly time. Both ' 
long (8-bit) register addressing and short 
(4-bit) working register addressing are sup- 
ported in this mode. Most instructions sup- 
porting this mode provide access to single 
8-bit ^registers. For example: 

LD %FE,#HI STACK 

!load register %FE(SPH) with 
the upper 8-bits of the label 
STACK! 

AND 0,MASK_REG 

!AND register with register 
named MASK_REG! 

OR 1,R5 !OR register 1 with working 
register 5! 

Increment word (INCW) and decrement 
word (DECW) are the only two Z8 instructions 
which access 16- bit operands. These instruc- 
tions are illustrated below for the direct reg- 
ister addressing mode. 

INCW RRO increment working register 
pairRO, Rl: 
Rl ^ Rl -H 1 
RO ^ RO -F carry! - 

DECW,%7E 

! decrement working register 
pair %7E, %7F: 
%7F ^, %7F - 1 
%7E <- %7E - carry! 

Note that the instruction 

INCW RR5 ' 

will be flagged as an error by the assembler 
(RR5 not even-numbered). 

2.4.2 Indirect Register Addressing. In this 
addressing mode, the operand is pointed to by 
the register whose 8-bit register address or 
4-bit working register address is given by the 
instruction. This mode is used when the target 
register address is not known at assembly time 
and must be calculated during program execu- 
tion. For example, assume registers %60-%7F 
contain a buffer for output to the serial line via 

repetitive calls to procedure SERIAL OUT. 

SERIAL OUT expects working register to 

hold the output character. The following 
instructions illustrate the use of the indirect 
addressing mode to accomplish this task: 

LD Rl,#%20 

! working register 1 is the byte 
counter: output %20 bytes! 



LD R2,#%60 

! working register 2 is the buf- 
fer pointer register! 
out again: 

LD, R0,@R2 

!load into working register 
the byte pointed to by working 
register 2! 

INC R2 ! increment pointer! 

CALL SERIAL_OUT 

! output the byte! 

DJNZ Rl,out_again 

!loop till done! 

Indirect addressing may also be used for 
accessing a 16-bit register pair via the INCW 
and DECW instructions. For example, 

INCW @R0 'increment the register pair 

whose address is contained in 

working register 0! 
DECW @%7F 

! decrement the register pair 

whose address is contained in 

register %7F! 

The contents of registers RO and %7F should 
be even numbers for proper access; when 
referencing a register pair, the least significant 
address bit is forced to the appropriate value 
by the Z8. However, the register used to point 
to the register pair need not be an even- 
numbered register. 

Since the indirect addressing mode permits 
calculation of a target address prior to the 
desired register access, this mode may be used 
to simulate other, more complex addressing 
modes. For example, the instruction 

SUB 4,BASE(R5) 

reguires the indexed addressing mode which is 
not directly supported by the Z8 SUBtract 
instruction. This instruction can be simulated 
as follows: 

LD R6,#BASE 

! working register 6 has the 

base address! 
ADD R6,R5 Icalculate the target address! 
SUB 4,@R6 !now use indirect addressing to 

perform the actual subtract! 

Any available register or working register 
may be used in place of R6 in the 
above example. 

2.4.3 Indexed Addressing. The indexed 
addressing mode is supported by the load 
instruction (LD) for the transference of bytes 
between a working register and anotlier regis- 
ter. The effective address of the latter register 
is given by the instruction whigh is offset by 
the contents of a designated working (index) 
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2. Accessing 

Register 

Memory 

(Continued) 



register. This addressing mode provides 
efficient memory usage when addressing 
consecutive bytes in a block of register 
memory, such as a table or a buffer. The 
working register used as the index in 
the effective address calculation can 
serve the additional role of counter for 
control of a loop's duration. 

For example, assume an ASCII character 
buffer exists in register memory starting at 
address BUF for LENGTH bytes. In order 
to determine the logical length of the char- 
acter string, the buffer should be scanned 
backward until the first nonoccurrence of a 
blank character. The following code 
seguence may be used to accomplish 
this task: 

LD RO,#LENGTH 

! length of buffer! 
[starting at buffer end, look for 
1st non-blank! 



loop: 
LD 
CP 
JR 



-l(RO) 



R1,BUF- 
RIJ" 
ne, found 

!found non-blank! 
DJNZ RO,loop 

!look at next! 
all_blanks: !length = 0! 
found: 

5 instructions 

12 bytes 

1.5 /ts overhead 

10.5 fjLS (average) per character tested 

At labels ''all blanks" and "found," RO 

contains the length of the character 
string. These labels may refer to the same 
location, but they are shown separately for 
an application where special processing is 
reguired for a string of zero length. To per- 
form this task without indexed address- 
ing would reguire a code seguence 
such as: 



LD R1,#BUF + LENGTH -I 
LD RO,#LENGTH 

! starting at buffer end, look for 

1st non-blank! 



loopl: 
CP 
IR 



@R1,#' ' 
ne,foundl 

! found non-blank! 
DEC RI !dec pointer! 
DINZ BO,loopl 

!are we done?! 
all_blanksl: ! length = 0! 
foundl: 

6 instructions 

13 bytes 

3 fis overhead 

9.5 /xs (average) per character tested 

The latter method reguires one more byte of 
program memory than the former, but is faster 
by four execution cycles (1 ^s) per character 
tested. 

As an alternate example, assume a buffer 
exists as described above, but it is desired to 
scan this buffer forward for the first occur- 
rence of an ASCII carriage return. The follow- 
ing illustrates the code to do this: 

LD R0,#- LENGTH 

! starting at buffer start, look for 
1st carriage return ( = %0D)! 



next: ~ 
LD 
CP 
IR 
INC 
JR 



rl,BUF-hLENGTH(RO) 

R1,#%0D 

eg,cr !found it! 

RO ! update counter/index! 

nz,next 

!try again! 



cr: 



ADD RO,#LENGTH 

• !R0 has length to CR! 
7 instructions 
16 bytes 
1 . 5 jLis overhead 
12 /iS (average) per character tested 



SECTION 

3 



Accessing Program and External Data 
Memory 

In a single instruction, the Z8 can transfer a 
byte between register memory and either pro- 
gram or external data memory. Load' Constant 
(LDC) and Load Constant and Increment 
(LDCI) reference program memory; Load 
External (LDE) and Load External and Incre- 
ment (LDEI) reference external data memory. 
These instructions reguire that a working 
register pair contain the address of the byte in 
either program or external data memory to be 
accessed by the instruction (indirect working 
register pair addressing mode). The register 
byte operand is specified by using the direct 
working register addressing mode in LDC and 



LDE or the indirect working register address- 
ing mode^ in LDCI and LDEI. In addition to 
performing the designated byte transfer, LDCI 
and LDEI automatically increment both the 
indirect registers specified by the instruction. 
These instructions are therefore efficient for 
performing block moves between register and 
either program or external data memory. Since 
the indirect addressing mode is used to specify 
the operand address within program or exter- 
nal data memory, more complex addressing 
modes may be simulated as discussed earlier 
in Section 2.4.2. For ex,ample, the instruction 

LDC R3,BASE(R2) ' ' 

reguires the indexed addressing mode, where 
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3. Accessing BASE is the base address of a table in program 
Program and memory and R2 contains the offset from table 
External Data start to the desired table entry. The following 
Memory code sequence simulates this instruction with 

(Continued) the use of two additional registers (RO and Rl 
in this example). 

LD ROJHI BASE 
LD RIJLOBASE 

!RRO has table start address! 
ADD R1,R2 
ADC R0,#0 

!RRO has table entry address! 
LDC R3,@RR0 

!R3 has the table entry! 

3.1 Configuring the Z8 for I/O Applications 
vs. Memory Intensive Applications. The Z8 

offers a high degree of flexibility in memory 
and I/O intensive applications. Thirty-two port 
bits are provided of which 16, 12, eight, or 
zero may be configured as address bits to 
external memory. This allows for addressing of 
62K, 4K or 256 bytes of external memory, 
which can be expanded to 124K, 8K, or 512 
bytes if the Data Memory Select output (DM) is 
used to distinguish between program and data 
memory accesses. The following instructions 
illustrate the code sequence required to con- 
figure the Z8 with 12 external addressing lines 
and to enable the Data Memory Select output. 



LD P01M,#%(2)00010010 

!bit 3-4: enable AD0-AD7; 
bit 0-1: enable As-An! 

LD P3M,r/o(2)00001000 

!bit 3-4: enable DM! 

The two bytes following the mode selection of 
ports and 1 should not reference external 
memory due to pipelining of instructions within 
the Z8. Note that the load instruction to P3M , 
satisfies this requirement (providing that it 
resides within the internal 2K bytes of 
memory) . 

3.2 LDC and LDE. To illustrate the use of the 

Load Constant (LDC) and Load External (LDE) 
instructions, assume there exists a hardware 
configuration with external memory and Data 
Memory Select enabled. The following module 
illustrates a program for tokenizing an ASCII 
input buffer. The program assumes there is a 
list of delimiters (space, comma, tab, etc.) in 
program memory at address DELIM for 
COUNT bytes (accessed via LDC) and that an 
ASCII input buffer exists in external data 
memory (accessed via LDE). The program 
scans the input buffer from the current location 
and returns the start address of the next token 
(i.e. the address of the first nondelimiter 
found) and the length of that token (number of 
characters from token start to next delimiter). 



Z8ASM 
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LOC 


OBJ 


CODE 


STMT SOURCE STATEMENT 














1 


SCAN 


MODULE 














2 


CONSTANT 














3 


COUNT 


: - 


6 












4 


GLOBAL 
















5 




$SECTIOrJ 


1 PROGRAM 


P 0000 


20 


3B 


2C 


6 


DELIM. 


ARRAY 


[COUNT 


BYTE] 


P 0003 


2E 


OA 


OD 













P 0006 



P 0006 BO 


E2 


P 0008 82 


30 


P OOOA AO 


EO 


P OOOC D6 


002E' 


P OOOF FD 


0015' 


P 0012 8D 


0018' 



c 



, 5J0A ,, %ODl 



RRO 



address of current location 
within input buffer in external 
memory. 



RR4 
RRO 



P 0015 8D 0008' 



9 scan PROCEDURE 

11 Purpose = To find the next token within an 

12 ASCII buffer. 
13 

14 Input = 
15 
16 
17 

18 Output = 
19 
20 
21 
22 
23 
24 

26 ENTRY 

27 clr R2 !init. length counter! 

28 DO 

29 LDE R3,@RR0 !get- byte from input buffer! 

30 incw RRO !increment pointer! 

31 call check !look for non-delimiter! 

32 IF C THEN 

33 EXIT !found token start! 

34 FI 

35 OD , 



address of start of next token 
address of new token's ending 
delimiter 

R2 = length of token 

R3 = ending delimiter 

R6,R7,R8,R9 destroyed 
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P 0018 48 EO 
P 001A 58 El 



P 001C 2E 

P 001D 82 

P 001F D6 

P 0022 7D 

P 0025 8D 



P 002E 



P 002E 6C 
P 0030 7C 



0034 C2 
0036 AO 
003^- A2 
003A 6B 
003C 8A 
003E DF 



P 003F AF 
P 0040 



30 

002E' 
0028' 
002D' 



P 0028 AO EO 
P 002A 8D OOIC 



P 002D AF 
P 002E 



00* 
00* 



P 0032 8C 06 



96 
E6 
93 
03 
F6 



36 
37 
38 
39 
40 
41 
42 
43 
44 
45 
46 
47 
48 
49 
50 

51 
52 
53 
54 
55 
56 
57 
58 
59 
60 
61 
62 
63 
64 
65 
66 
67 
68 
69 



Id 


R4,R0 


Id 


R5,R1 


DO 




inc 


R2 


LDE 


R3,@R 


call 


check 


IF NC 


THEN 


■ EXIT 




FI 




incw 


RRO 


CD 




ret 




scan 





!RR4 = token starting- addr! 

line, length counter! 
R3,@RR0 'get next input byte! 
!look for delimiter! 

!found token end! 

!point to next byte! 



END 

check PROCEDURE 

Purpose = compare current character with 
delimiter table until table 
end or match found 

input = DELIM = start address of table 
COUNT = length of that table 
R3 = byte to be scrutinized 

output = Carry flag = 1 => input byte 

is not a delimiter (no match found) 

Carry flag = => input byte 
is a delimiter (match found) 
R6,R7,R8,R9 destroyed 



70 ENTRY 

71 

72 

73 

74 

75 here: 

76 

77 

78 

79 

80 

81 

82 

83 bye: 

84 

85 END 

86 END 



Id 
Id 

Id 

LDC 

incw 

cp 

jr 

djnz 

scf 



ret 

check 

SCAN 



R6,#HI DELIM 
R7,#L0 DELIM 

R8,#C0UNT 

R9,@RR6 

RR6 

R9,R3 

eq,bye 

R8,here 



!RR6 points to 
delimiter list! 
!R8 = length of list! 

!get table entry! 
!point to next entry! 
!R3 = delimiter?! 
!yes. carry = 0! 
!next entry! 
!table done. R3 
not a delimiter! 



ERRORS 
ASSEMBLY COMPLETE 



27 instructions 

58 bytes 

Execution time is a function of the number of leading delimiters 
before token start (x) and the number of characters in the 
token (y): 123 fis overhead + 59x /as + 102y fis 
(average) per token 



3.3 LDCI. A common function performed in Z8 
applications is the initialization of the register 
space. The most obvious approach to this func- 
tion is the coding of a sequence of "load 
register with immediate value" instructions 
(each occupying three program bytes for a 



register or two program bytes for a working 
register). This approach is also the most effi- 
cient technique for initializing less than eigiit 
consecutive registers or 14 consecutive work- 
ing registers. For a larger register block, the 
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3. Accessing LDCI instruction provides an economical 
Program and means of initializing consecutive registers from 
External Data an initialization table in program memory. The 
Memory following code excerpt illustrates this tech- 

( Continued) nique of initializing control registers %F2 

through %FF from a 14-byte array (INIT tab) 

in program memory: 

SRP #%00 

!RP not %F0! 
LD R6,#HI INIT_tab 
LD R7,#LO INIT_tab 
LD R8,#%F2 

list reg to be initialized! 
LD R&,#14 

! length of register block! 
loop: 

LDCI @R8,@RR6 

!load a register from the 

init table! 
DJNZ R9,loop 

! continue till done! 
7 instructions 
14 bytes 
7.5 )Lts overhead 
7.5 jKS per register initialized 



3.4 LDEI. The LDEI instruction is useful for 
moving blocks of data between external and 
register memory since auto-increment is per- 
formed on both indirect registers designated 
by the instruction. The following code excerpt 
illustrates a register buffer being saved at 
address %40 through %60 into external 
memory at address SAVE: 

LD R10,#HI SAVE 

! external memory! 
LD RllJLOSAVE 

! address! 
LD R8,#%40 

{starting register! 
LD R9,#%21 

! number of registers to save in 

external data memory! 
loop: 

LDEI @RR10,@R8 

, !init a register! 
DJNZ R9,loop 

! until done! 
6 instructions 
12 bytes 
6 /Lis overhead 
7.5 jLts per register saved 



SECTION 
4 



Bit Manipulations 

Support of the test and modification of an 
individual bit or group of bits is required by 
most software applications suited to the Z8 
microcomputer. Initializingyand modifying the 
Z8 contrpl registers, polling interrupt requests, 
manipulating port bits for control of or com- 
munication with attached devices, and manipu- 
lation of software flags for internal control pur- 
poses are all examples of the heavy use of bit 
manipulation functions. These examples illus- 
trate the need for such functions in all areas of 
the Z8 register space. These functions are sup- 
ported in the Z8 primarily by six instructions: 

■ Test under Mask (TM) 

■ Test Complement under Mask (TCM) 

■ AND 

■ OR 

■ XOR 

■ Complement (COM) 

These instructions may access any Z8 register, 
regardless of its inherent type (control, I/O, or 
general purpose), with the exception of the six 
write-only control registers (PREO, PREl, 
POIM, P2M, P3M, IPR) mentioned earlier in 
Section 2.1. Table 1 summarizes the function 
performed on the destination byte by each of 
the above instructions. All of these instruc- 
tions, with the exception of COM, require a 
mask operand. The "selected" bits referenced 
in Table 1 are those bits in the destination 
operand for which the corresponding mask bit 
is a logic 1 . . ^ 



Opcode 



Use 



TM To test selected bits for logic 

TCM To test selected bits for logic 1 

AND To reset all but selected bits to logic 

OR To set selected bits to logic 1 

XOR To complement selected bits 

COM To complement all bits 

Table 1. Bit Manipulation Instruction Usage 

The instructions AND, OR, XOR, and COM 
have functions common to today's micro- 
processors and therefore are not described in 
depth here. However, examples of the use of 
these instructions are laced throughout the 
remainder of this document, thus giving an 
integrated view of their uses in common func- 
tions. Since they are unique to the Z8, the 
functions of Test under Mask and Test Comple- 
ment under Mask, are discussed in more detail 
next. 

4.1 Test under Mask (TM). The Test under 
Mask instruction is used to test selected bits for 
logic 0. The logical operation performed is 

. destination AND source 

Neither source nor destination operand is 
modified; the FLAGS control register is the 
only register affected by this instruction. The 
zero flag (Z) is set if all selected bits are logic 
0; it is reset otherwise. Thus, if the selected 
destination bits are either all logic 1 or a com- 
bination of Is and Os, the zero flag would be 
cleared by this instruction. The sign flag (S) is 
either get or reset to reflect the result of the 
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,4. Bit AND operation; the overflow flag (V) is always 

Manipu- reset. All other flags are unaffected. Table 2 

lations illustrates the flag settings which result from 

(Continued) the TM instruction on a variety of source and 
destination operand combinations. Note that a 
given TM instruction will never result in both 
the Z and S flags being set. 

4.2 Test Complement under Mask. The Test 
Complement under Mask instruction is used to 
test selected bits for logic 1 . The logical opera- 
tion performed is 

(NOT destination) AND source. 



Destination 



Source 



Flags 



(binary) 
10001 100 
01111100 
10001100 
11111100 
00011000 
01000000 



(binary) 


Z 


s 


V 


01110000 


1 








01110000 











11110000 





1 





11110000 





1 





10100001 


1 








10100001 


1 









As in Test under Mask, the FLAGS control 
register is the only register affected by this 
operation. The zero flag (Z) is set if all selected 
destination bits are 1; it is reset otherwise. The 
sign flag (S) is set or reset to reflect the result 
of the AND operation; the overflow flag (V) is 
always reset. Table 3 illustrates the flag set- 
tings which result from the TCM instruction on 
a variety of source and destination operand 
combinations. As with the TM instruction, a 
given TCM instruction will never result in both 
the Z and S flags being set. 



Destination 



Source 



Flags 



(binary) 
10001100 
01111100 
10001100 
11111100 
00011000 
01000000 



(binary) 


Z 


s 


V 


01110000 











01110000 


1 








11110000 











11110000 


1 








iOlOOOOl 





1 





10100001 





1 






Table 2. Effects of the TM Instruction 



Table 3. Effects of the TCM Instruction 



SECTION 

5 



Stack Operations 

The Z8 stack resides within an area of data 
memory (internal or external). The current 
address in the stack is contained in the stack 
pointer, which decrements as bytes are pushed 
onto the stack, and increments as bytes are 
popped from it. The stack pointer occupies two 
control register bytes (%FE and %FF) in the 
Z8 register space and may be manipulated like 
any other register. The stack is useful for 
subroutine calls, interrupt service routines, 
and parameter passing and saving. Figure 2 
illustrates the downward growth of a stack as 
bytes are pushed onto it. 

5.1 Internal vs. External Stack. The location 
of the stack in data memory may be selected to 
be either internal register memory or external 
data memory. Bit 2 of control register POIM 
(%F8) controls this selection. Register pair 
SPH (%FE), SPL (%FF) serves as the stack 
pointer for an external stack. Register SPL is 
the stack pointer for an internal stack. In the 



SP — 




SP — 




SP — 




-1 




R1 


R1 


-2 






PC LOW 


-3 






PC HIGH 


-4 









latter configuration, SPH is available for use as 
a data register. The following illustrates a code i 
sequence that initializes external stack opera- 
tions: 

LD P01M,#%(2)00000000 

!bit 2: select external stack! 
LD SPH,#HI STACK 
LD SPL,#LO STACK 

5.2 CALL. A subroutine call causes the cur- 
rent Program Counter (the address of the byte 
following the CALL instruction) to be pushed 
onto the stack. The Program Counter is loaded 
with the address specified by the CALL 
instruction. This address may be a direct 
address or an indirect register pair reference. 
For example. 



LABEL 1: 



CALL %4F98 

Idirect addressing: PC is 
loaded with the hex value 
4F98; 

address LABEL 1 + 3 is pushed 
onto the stack! 



LABEL 2: CALL 

indirect addressing: PC is 
loaded with the contents of 
working register pair R4, R5; 
address LABEL 2 + 2 is pushed 
onto the stack! 



Figure 2. Growth of a Stack 
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5. Stack LABEL 3: CALL @%7E 

Operations indirect addressing: PC is 

(Continued) ' loaded with the contents of 

register pair %7E, %7F; 

address LABEL 3 + 2 is pushed 

onto the stack! 

5.3 RET. The return (RET) instruction causes 
the top two bytes to be popped from the stack 
and loaded into the Program Counter. Typi- 
cally, this is the last instruction of a subroutine 
and thus restores the PC to the address foilow- 
ing the CALL to that subroutine. 

5.4 Interrupt Machine Cycle. During an inter- 
rupt machine cycle, the PC followed by the 
status' flags is pushed onto the stack. (A more 
detailed discussion of interrupt processing is 
provided in Section 6.) 

5.5 IRET. The interrupt return (IRET) instruc- 
tion causes the top byte to be popped from the 
stack and loaded into the status flag register, 
FLAGS (%FC); the next two bytes are then 
popped and loaded into the Program Counter. 
In this way, status is restored and program 
execution continues where it had left off when 
the interrupt was recognized. 

5.6 PUSH and POP. The Pl)SH and POP 
instructions allow the transfer of bytes between 



the stack and register memory, thus providing 
program access to the stack for saving and 
restoring needed values and passing 
parameters to subroutines. 

Execution of a PUSH instruction causes the 
stack pointer to be decremented by 1 ; the 
operand byte is then loaded into the location 
pointed to by the decremented stack pointer. 
Execution of a POP instruction causes the byte 
addressed by the stack pointer to be loaded 
into the operand byte; the stack pointer is then 
incremented by 1 . In both cases, the operand 
byte is designated by either a direct register 
address or an indirect register reference. For 
example: 

PUSH Rl ! direct address: push working 
register 1 onto the stack! 

POP 5 ! direct address: pop the top 

stack byte into register 5! 

PUSH @R4 ! indirect address: pop the top 
stack byte into the byte 
pointed to by working reg- 
ister 4! 

PUSH @17 ! indirect address: push onto 
the stack the byte pointed to 
by register 17! 



SECTION Interrupts 

g The Z8 recognizes six different interrupts 

from four internal and four external sources, 
including internal timer/counters, serial I/O, 
and four Port 3 lines. Interrupts may be indi- 
vidually or globally enabled/disabled via Inter- 
rupt Mask Register IMR (%FB) and may be 
prioritized for simultaneous interrupt resolution 
via Interrupt Priority Register IPR (%F9). 
When enabled, interrupt request processing 
automatically vectors to the designated service 
routine. When disabled, an interrupt request 
may be polled to determine when processing is 
needed . 

6.1 Interrupt Initialization. Before the Z8 can 
recognize interrupts following RESET, some 
initialization tasks must be performed. The ini- 
tialization routine should configure the Z8 
interrupt requests to be enabled/disabled, as 
required by the target application and 
assigned a priority (via IPR) for simultaneous 
enabled-interrupt resolution. An interrupt 
request is enabled if the corresponding bit in 
the IMR is set ( = 1 ) and interrupts are 
, globally enabled (bit 7 of IMR = I). An inter- 
rupt request is disabled if the corresponding 
bit in the IMR is reset ( = 0) or interrupts are 
globally disabled (bit 7 of IMR = 0). 

A RESET of the Z8 causes the contents of the 
Interrupt Request Register IRQ (%FA) to be 
held to zero until the execution of an EI 



instruction. Interrupts that occur while the Z8 
is in this initial state will not be recognized, 
since the corresponding IRQ bit cannot be set. 
The EI instruction is specially decoded by the 
Z8 to enable the IRQ; simply setting bit 7 of 
IMR is therefore not sufficient to enable inter- 
rupt processing following RESET-. However, 
subsequent to this initial EI instruction, inter- 
rupts may be globally enabled either by the 
instruction . , 



EI 



! enable interrupts! 



or by a register manipulation- instruction 
such as 

OR IMR,#%80 

To globally disable interrupts, execute the 
instruction 



DI 



!disable interrupts! 



This will cause bit 7 of IMR to be reset. 

Interrupts must be globally disabled prior to 
any modification of the IMR, IPR or enabled 
bits of the IRQ (those corresponding to 
enabled interrupt requests), unless it can be 
guaranteed that an enabled interrupt will not 
occur during the processing of such instruc- 
tions. Since interrupts represent the occur- 
rence of events asynchronous to program exe- 
cution, it is highly unlikely that such a 
guarantee can be made reliably. 



210 



6. Interrupts 6.2 Vectored Interrupt Processing. Enabled 
(Continued) interrupt requests are processed in an 

automatic vectored mode in which the inter- 
rupt service routine address is retrieved from 
within the first 12 bytes of program memory. 
When an enabled interrupt request is 
recognized by the Z8, the Program Counter is 
pushed onto the stack (low order 8 bits first, 
then high-order 8 bits) followed by the FLAGS 
register (#%FC). The corresponding interrupt 
request bit is reset in IRQ, interrupts are 
globally disabled (bit 7 of IMR is reset), and 
an indirect jump is taken on the word in loca- 
tion 2x, 2x+ 1 (x = interrupt request number, 
0<x<5). For example, if the bytes at 
addresses %0004 and %0005 contain %05 and 
%78 respectively, the interrupt machine cycle 
for IRQ2 will cause program execution to con- 
tinue at address %0578. 

When interrupts are sampled, more than one 
interrupt may be pending. The Interrupt Prior- 
ity Register (IPR) controls the selection of the 
pending interrupt with highest priority. While 
this interrupt is being serviced, a higher- 
priority interrupt may occur. Such interrupts 



may be allowed service within the current 
interrupt service routine (nested) or may be 
held until the current service routine is com- 
plete (non-nested). 

To allow nested interrupt processing, inter- 
rupts must be selectively enabled upon entry 
to an interrupt service routine. Typically, only 
higher-priority interrupts would be allowed to 
nest within the current interrupt service. To do 
this, an interrupt routine must "know" which 
interrupts have a higher priority than the cur- 
rent interrupt request. Selection of such nest- 
ing priorities is usually a reflection of the 
priorities established in the Interrupt Priority 
Register (IPR). Given this data, the first, 
instructions executed in the service routine 
should be to save the current Interrupt Mask 
Register, mask off all interrupts of lower and 
equal priority, and globally enable interrupts 
(EI). For example, assume that service of inter- 
rupt requests 4 and 5 are nested within the ser- 
vice of interrupt request 3. The following illus- 
trates the code required to enable IRQ4 
and IRQ5: 



CONSTANT 

INT_MASK_3 
GLOBAL 

IRQ3 service 

[service routine for IRQ3! 

PUSH IMR 



PROCEDURE 



%(2) 00110000 



ENTRY 



END IRQ3_ 



AND 
EI 
I I 



DI 
POP 
IRET 
.service 



!save Interrupt Mask Register! 
[interrupts were globally disabled during the interrupt 
machine cycle - no DI is needed prior to modification of IMR! 
IMR,#INT_MASK_3 ! disable all but IRQ4 & 5! 

! service interrupt! 

! interrupts are globally enabled now — must disable them prior to 
modification of IMR! 



IMR 



[restore entry IMR, 



interrupts, the following code sequence could 
be used: 

POP FLAGS 

! FLAGS 

RET !PC ^- 

This accomplishes all the functions of IRET, 
except that IMR is not affected. 

6.3 Polled Interrupt Processing Disabled 
interrupt requests may be processed in a , 
polled mode, in which the corresponding bits 
of the Interrupt Request Register (IRQ) are 
examined by the software'. When an interrupt 
request bit is found to be a logic 1 , the inter- 
rupt should be processed by the appropriate 



Note that IRQ4 and IRQ5 are enabled by the 
above sequence only if their respective IMR 
bits = 1 on entry to IRQ3__service. 

The service routine for an interrupt whose 
processing is to be completed without interrup- 
tion should not allow interrupts to be nested 
within it. Therefore, it need not modify the 
IMR, since interrupts are disabled automati- 
cally during the interrupt mcf chine cycle. 

The service routine for an enabled interrupt 
is typically concluded with an IRET instruc- 
tion, which restores the FLAGS register and 
Program Counter from the top of the stack and 
globally enables interrupts. To return from an 
interrupt service routine without re-enabling 
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6. Interrupts service routine. During such processing, the 
(Continued) interrupt request bit in the IRQ must be 

cleared by the software in order for subsequent 
interrupts on that line to be distinguished from 
the current one. If more than one interrupt 
request is to be processed in a polled mode, 
polling should occur in the order of estab- 



lished priorities. For exapiple, assume that 
IRQO, IRQl, and IRQ4 are to be polled and 
that established priorities are, from high to 
low, IRQ4, IRQO, IRQl. An instruction 
sequence like the following should be used to 
poll and service the interrupts: 



Ipoll interrupt inputs here! 

TCM IRQ, #0/0(2)00010000 

JR NZ, TESTO 

CALL IRQ4__service 

TESTO: TCM IRQ, #%(2)00000001 

JR NZ, TESTl 

CALL IRQO_service 

TESTl: TCM IRQ, #%(2)00000010 

JR NZ, DONE 

CALL IRQ l_ser vice 

DONE: L..! 



IRQ4 service . 

AND 

RET 
END IRQ4_service 

IRQO service 

AND 

RET 
END IRQO_service 

IRQl service 

! . . . ! 
AND 
!...! 
RET 

END IRQl_service 

I I 



PROCEDURE 

IRQ, #%(2)111 11101 



ENTRY 



!IRQ4 need service?! 

!no! 

!yes! 

!IRQO need service?! 

!no! 

!yes! 

!IRQ1 need service?! 

!no! , ' 

!yes! 



PROCEDURE ENTRY 

IRQ, #%(2)1 11011 11 !clear IRQ4! 

PROCEDURE ENTRY 

IRQ, #%(2)11111110 ! clear IRQO! 



! clear IRQl! 



SECTION Timer/Counter Functions 

W9 The Z8 provides two 8-bit timer/counters, Tq 

and Ti, which are adaptable to a variety of 
application needs and thus allow the software 
(and external hardware) to be relieved of the 
bulk of such tasks. Included in the set of such 
uses are: 

■ Interval delay timer 

■ Maintenance of a time-of-day clock 

■ Watch-dog timer 

■ External event counting 

■ Variable pulse train output 

■ Duration measurement of external event 

■ Att^matic delay following external event 
detection 



Each timer/counter is driven by its own 6-bit 
prescaler, which is in turn driven by the inter- 
nal Z8 clock divided by four. For Tj, the inter- 
nal clock may be gated or triggered by an 
external event or may be replaced by an exter- 
nal clock input. Each timer/counter may 
operate in either single-pass or continuous 
mode where, at end-of-count, either counting 
stops or the counter reloads and continues 
counting. The counter and prescaler registers 
may be altered individually while the timer/ 
counter is running; -the software controls 
whether the new values are loaded immedi- 
ately or when end-of-count (EOC) is reached. 

Although the timer/counter prescaler 
registers (PREO and PREl) are write-only, 
there is a technique by which thd timer/ 
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7. Timer/ 

Counter 

Functions 

(Continued) 



counters may simulate a readable prescaler. 
This capability is a requirement for high 
resolution measurement of an event's duration. 
The basic approach requires that one timer/ 
counter be initialized with the desired counter 
and prescaler values. The second timer/ 
counter is initialized with a counter equal to 
the prescaler of the first timer/counter and a 
prescaler of 1 . The second timer/counter must 
be programmed for continuous mode. With 
both timer/counters driven by the internal 
clock and started and stopped simultaneously, 
they will run synchronous to one another; thus, 
the value read from the second counter will 
always be equivalent to the prescaler of 
the first. 

7.1 Time/Count Interval Calculation To 
determine the time interval (i) until EOC, the 
equation 

i = t X p X v 

characterizes the relation between the 
prescaler (p), counter (v), and clock input 
period (t); t is given by 

l/(XTAL/8) 

where XTAL is the Z8 input clock frequency; 
p is in the range 1 ^ 64; v is in the range 
1 - 256. When programming the prescaler and 
counter registers, the maximum load value is 
truncated to six and eight bits, respectively, 
and is therefore programmed as zero. For an 
input clock frequency of 8 MHz, the prescaler 
and counter register values may be pro- 
grammed to time an interval in the range 

I (IS X 1 X 1 < i < 1 |is X 64 X 256 

1 ^s < i < 16.384 ms ' 

To determine the count (c) until EOC for Ti 
with external clock input, the equation 

c = p X V 

characterizes the relation between the Tj ., 
prescaler (p) and the Ti counter (v). The 
divide-by-8 on the input frequency is bypassed 
in this mode. The count range is 

1 X 1 < c < 64 X 256 

1 < c < 16,384 

7.2 Tout Modes. Port 3, bit 6 (P36) may be 
configured as an output (Tqut) which is 
dynamically controlled by one of the following: 

■To 
■ Ti 

ip Internal clock 

When driven by Tq or Ti, Tqut is reset to a 
logic 1 when the corresonding load bit is set in 
timer control register TMR (%F1) and toggles 
on EOC from the corresponding counter. 



When Tout is driven by the internal clock, 
that clock is directly output on P36. 

While programmed as TquT, P36 is disabled 
from being modified by a write to port register 
%03; however, its current output may be 
examined by the Z8 software by a read to port 
register %03. 

7.3 Tin Modes. Port 3, bit UP3i) may be con- 
figured as an input (Tj^) wBfe is used in con- 
junction with Ti in one of four modes: 

■ External clock input 

■ Gate input for internal clock 

■ Nonretriggerrable input for internal clock 

■ Retriggerable input for internal clpck 

For the latter two modes, it should be noted 
that the existence of a synchronizing circuit 
within the Z8 causes a delay of two to three 
internal clock periods following an external 
trigger before clocking of the counter actually 
begins. 

Each High-to-Low transition on Tji^ will 
generate interrupt request IRQ2, regardless of 
the selected Tj/^ mode or the enabled/disabled 
state of Tj. IHQ2 i;nust therefore be masked or 
enabled according to the heeds of the 
application. 

The ''external clock input" Tin mode sup- 
ports the counting of external events, where an 
event is seen as a High-to-Low transition on 
Tin. Interrupt request IRQ5 is generated on 
the nth occurrence (single-pass mode) or on 
every n^h occurrence (continuous mode) of 
that event. 

The "gate input for internal clock" Tin niode 
provides for duration measurement of an exter- 
nal event. In this mode, the Ti prescaler is 
driven by the Z8 internal clock., gated by a 
High level on Tin- In other words, Ti will 
count while Tin is High and stop counting 
while Tin is Low. Interrupt request IRQ2 is 
generated on the High-to-Low transition on 
Tin. Interrupt request IRQ5 is generated on Ti 
EOC. This mode may be used when the width 
of a High-going pulse needs to be measured. 
In this mode, IRQ2 is typically the interrupt 
request of most importance, since it signals the 
end of the pulse being measured. If IRQ5 is 
generated prior to IRQ2 in this mode, the 
pulse width on Tin is too large for Ti to 
measure in a single pass. 

The ''nonretriggerable input" Tin mode Pro- 
vides for automatic delay timing following an 
external event. In this mode, Ti is loaded and 
clocked by the Z8 internal clock following the 
first High-to-Low transition on Tin ..after Ti is 
enabled. Tin transitions that occur after this 
point do not affect Ti. In singlp-pass mode, the 
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7. Timer/ enable bit is reset on EOC; further Tin transi- 

Counter tions will not cause T} to load and begin count- 

Tunctions ing until the software sets the enable bit again. 

(Continued) In continuous., mode, EOC does not modify the 
enable bit, but the counter is reloaded and 
counting continues immediately; IRQ5 is 
generated every EOC until software resets the 
enable bit. This Tin mode may be used, for 
example, to time the line feed delay following 
end of line detection on a printer or to delay 
data sampling for some length of time follow- 
ing a sample strobe. ■ ^ 

The 'Vetriggerable input" Tin mode will load 
and clock Ti with the Z8 internal clock on 
every occurrence of a High-to-Low transition 
on Tin- Ti will time-out and generate interrupt 
, request IRQ5 when the programmed time 
interval (determined by Ti prescaler and load 
register values) has elapsed since the last 
High-to-Low transition on Tin. In single-pass 
mode, the enable bit is reset on EOC; further 
Tin transitions will not cause Ti to load and 
begin counting until the software sets the 
enable bit again. In continuous mode, EOC 
does not modify the enable bit, but the counter 
is reloaded and counting continues immedi- 



ately; IRQ5 is generated at every EOC until 
the software resets the qnable bit. This Tin 
mode may provide such functions as watch-dog 
timer (e.g., interrupt if conveyor belt stopped 
qr clock pulse missed), or keyboard time-out 
(e.g., interrupt if no input in x ms). 

7.4 Examples. Several possible uses of the 
timer/counters are given in the following four 
examples. 

7.4.1 Time of Day Clock. The following 
module illustrates the use of Ti for 
maintenance of a time of day clock, which is 
kept in binary format in terms of hours, 
minutes, seconds, and hundredths of a second. 
It is desired that the clock be updated once 
every hundredth of a second; therefore, Ti is 
programmed in continuous mode to interrupt 
100 times a second. Although Ti is used for 
-this example, Tq is equally suited for the task. 
The procedure for initializing the timer 

(TOD INIT), the interrupt service routine 

(TOD) which updates the clock, and the inter-' 
rupt vector for Ti end-of-courit (IRQ_5) are 
illustrated below. XTAL = 7.3728 MHz is 
assumed. 
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ENTRY 




PROCEDURE 




P 0000 E6 


F3 


93 


16 


I 


.D. 


PRE1,#%(2)10010011 








17 




<i 




!bit 2-7: prescaler = 36; 








18 








bit 1 : internal clock; 








19 








bit 0: continuous mode! 


P 0003 E6 


F2 


00 


20 
21 




.D 


T1,#0 


!(256) time-out = 
1/100 second! 


P 0006 46 


F1 


OC 


22 




DR 


TMR,#%OC 


!load, enable TI ! 


P 0009 8F 






23 




DI 






P OOOA 46 


FB 


20 


24 




DR 


IMR,#%20 


!enable TI interrupt! 


P OOOD 9F 






25 




11 






P OOOE AF 






26 




RET 






P OOOF 






27 


END 


rOD_INIT 










28 










P OOOF 






29 


TOD 


PROCEDURE 










30 


ENTRY 








P OOOF 70 


FD 




31 




PUSH 


RP 










32 


iWorking 


register file %10 


to %1F contains 








33 


the tim 


g of day clock! 




P 0011 31 


10 




34 




SRP 


imo 




P 0013 FE 






35 




INC 


HUND 


! 1 more .01 sec! 


P 0014 A6 


EF 


64 


36 




CP 


HUND, #100 


!full second yet?! 


P 0017 EB 


13 




37 




JR 


NE,T0D.EXIT Ijump if no! 


P 0019 BO 


EF 




38 




CLR 


HUND 




P 001B EE 






39 




INC 


SECOND 


!1 more second! 


P 00 1C A6 


EE 


3C 


40 




CP 


SECOND, #60 


!full minute yet?! 


P 00 IF EB 


OB 




41 




JR 


NE,TOD_EXIT !jump if no! 
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Counter 

Functions 

(Continued) 



P 0021 BO 


EE 




42 




CLR , 


SECOND 




P 0023 DE 






43 




INC 


MINUTE 


! 1 more minute ! 


P 0024 A6 


ED 


3C 


44 




CP 


MINUTE, #60 


!full hour yet?! 


P 0027 EB 


03 




45 




JR 


NE,TOD_EXIT 


!jump if no! 


P 0029 BO 


ED 




, 46 




CLR 


MINUTE 




P 002B CE 






47 
48 


T0D_ 


INC 
EXIT: 


HOUR 




P 002C 50 


FD 




49 




POP 


RP 


!restore entry RP! 


P 002E BF 






50 




IRET 






P 002F- 






51 
52 


END 
END 


TOD 
TIMER1 






ERRORS 














ASSEMBLY COMPLETE 












TOD^INIT: 










TOD: 






7 instructions 








17 instruction 




15 bytes 










32 bytes 




16,vs 










19.5 IIS 


(average) including interrupt response time 



7.4.2 Variable Frequency, Variable Pulse 
Width Output. The following module 
illustrates one possible use of Tqut- Assume it 
is necessary to generate a pulse train with a 
10% duty cycle, where the output is repetitive- 
ly high for 1.6 ms and then low for 14.4 ms. To 
do this, Tout is controlled by end-of-count 
from Ti, although To could alternately be 
chosen. This example makes use of the Z8 
feature that allows a timfer's counter register to 
be modified without disturbing the count in 
progress. In continuous mode, the new value is 
loaded when Ti reaches EOC. Ti is first 
loaded and enabled with values to generate 
the short interval. The counter register is then 
immediately modified with the value to 
generate the long interval; this value is loaded 
into the counter automatically on Ti EOC. The 
prescaler selected value must be the same for 
both long and short intervals. Note that the 



initial loading of the Ti counter register is 
followed by setting the Ti load bit of timer con- 
trol register TMR (%F1); this action causes 
' Tout ^o be reset, to a logic 1 output. Each 
subsequent modification of the Ti counter 
register does not affect the current ToUT level, 
since the Ti load bit is NOT altered by the 
software. The new value is loaded on EOC, 
and Tout will toggle at that time. The Ti inter- 
rupt service routine should simply modify the 
Ti counter register with the new value, alter- 
nating between the long and short interval 
values. 

In the example which follows, bit of 
register %04 is used as a software flag to indi- 
cate which value was loaded last. This module 
illustrates the procedure for Ti/ToUT initializa- 
tion (PULSE INIT), the Ti interrupt service 

routine (PULSE), and the interrupt vector for 
Ti EOC (IRQ_5). XTAL = 8 MHz is assumed. 



Z8ASM 




2.0 










LOC 


OBJ 


CODE 


STMT SOURCE STATEMENT 












1 


TIMER2 MODULE 












2 


$SECTI0N PROGRAM 








*. 


3 


GLOBAL 












4 


!IRQ5 interrupt 


vector! 










. 5 


$ABS 


10 


P 0000 


0017' 




6 
7 
8 


IRQ_5 ARRAY 


[1 WORD] := [PULSE] 










$REL 




P OOOC 








9, 
10 


PULSE.INIT 
ENTRY 


PROCEDURE 


P 0000 


E6 


F3 


03 


11 
12 
13 
14 


LD 


PRE1, #^(2)00000011 

!bit 2-7: prescaler = 64; 
bit 1: internal clock; 
bit 0: continuous mode! 


P 0003 


E6 


F7 


00 


15 


LD 


P3M,#00 !bit 5: let P36 be Tout! 


P 0006 


E6 


F2 


19 


16 


LD 


T1,#25 !for short interval! 


P 0009 


8F 






17 


DI 




P OOOA 


46 


FB 


20 


18 


OR 


IMR, #55(2)00100000 !enable TI interrupt! 


P OOOD 


E6 


F1 


8C 


19 
20 
21 
22 
23 


LD 


TMR, #56(2)10001100 

!bit 6-7: Tout controlled 

by TI; 
bit 3: enable TI ; 
bit 2: load TI ! 










24 


!Set long interval counter, to be loaded on TI EOC! 


P 0010 


E6 


F2 


El 


25 


LD 


T1.#225 










26 


!Clear alternating flag for PULSE! 
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P 0013 BO 


04 




27 




CLR 


%04 


!= : 25 next; 


Counter 








28 








= 1 : 225 next ! 


Functions 


P 0015 9F 
P 0016 AF 






29 
30 


, 


EI 
RET 






(Continued) 


P 0017 






31 
32 
33 


END 


PULSE. 


INIT 






P 0017 






34 


PULSE 


PROCEDURE 












35 


ENTRY 










P 0017 E6 


F2 


El 


36 




LD 


T1,#225 


!new load value! 




P 001A B6 


04 


01 


37 




XOR 


%04,#1 


Iwhich value next?! 




P 001D 6B 


03 




38 




JR 


Z, PULSE EXIT 


ishould be 225! 




P'OOIF E6 


F2 


19 


39 
40 


PULSE 


LD 
EXIT: 


T1,#25 


! should be 25! 




P 0022 BF 






41 




IRET 








P 0023 






42 
43 


END 
END 


PULSE 
TIMER2 








ERRORS 
















ASSEMBLY COMPLETE 














PULSE_INIT: 










PULSE: 








10 instructions 








5 instructions 






23 bytes 










22 bytes 






23,is 










25 ns 


(average) including interrupt response time 



7.4.3 Cascaded Timer/Counters. For some 
applications it may be necessary to measure a 
greater time interval than a sinc^le timer/ 
counter can measure (16.384 ms). In this case, 
Tin and ToUT may be used to cascade To and 



-•i> TO INTERRUPT LOGIC (IRQ4) 



Ti to function as a single unit. ToUT/ program- 
med to toggle on Tq end-of-count, should be 
wired back to Tin, which is selected as the 
external clock input for Ti. With To program- 
med for continuous mode, Tqut (and therefore 
Tin) goes through a High-to-Low transition 
(causing Ti to count) on every other To EOC. 
Interrupt reguest IRQ5 is generated when the 
programmed time interval has elapsed. Inter- 
rupt reguests IRQ2 (generated on every Tin 
High-to-Low transition) and IRQ4 (generated 
on To EOC) are of ho importance in this 
application and are therefore disabled. 

To determine the time interval (i) until EOC, 
the eguation 



i = t X 



-► TO INTERRUPT LOGIC (IRQ5) 



pO X vO X (2 X pi X vl-1) 

characterizes the relation between the Tq 
prescaler (pO) and counter (vO), the Ti 
prescaler (pi) and counter (vl), and the clock 
input period (t); t is defined in Section 7.1. 
Assuming XTAL = 8 MHz, the measurable 
time interval range is 

I fis X 1 X 1 x(2x l-l)<i< 
■ 1 /is X 64 X 256 X (2 X 64 X 256 - 1) 

I lis < 1 < 536.854528 s 

Figure 3 illustrates the interconnection 
between Tq and T]. The following module 
illustrates the procedure reguired to initialize 
the timers for a 1.998 second delay interval: 



Figure 3. Gxscaded Timer/Counters 
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7. Timer/ 


Z8ASM 




2.0 












Counter 


LOG 


OBJ 


CODE 


STMT SOURCE 


STATEMENT 




Functions 










1 


TIMER3 


MODULE 




(Continued) 










2 


GLOBAL 








P 0000 








3 
4 


TIMER. 
ENTRY 


16 


PROCEDURE 




P 0000 


E6 


F3 


28 


5 
6 
7 
8 




LD 


PRE1,#%(2)00101000 

!bit 2-7: prescaler = 10; 
bit 1: external clock; 
bit 0: single-pass mode! 




P 0003 


E6 


F7 


00 


9 




LD 


P3M,#00 !bit 5: let P36 be Tout! 




P 0006 


E6 


F2 


64 


10 




LD 


T1,/n00 !T1 counter register! 




P 0009 


E6 


F5 


29 


11 
12 
13 




LD 


PREO,//%(2)00101001 

!bit 2-7: prescaler = 10; 
bit 0: continuous mode! 




P OOOC 


E6 


F4 


64 


14 




LD 


TO, #100 !T0 counter register! 




P OOOF 


8F 






15 




DI 






P 0010 


56 


FB 


2B 


16 
17 




AND 


IMR,#%(2)00101011 !disable IRQ2 (Tin); 
and IRQ4 (TO) ! 




P 0013 


46 


FB 


20 


18 




OR 


IMR,#%(2)00100000 !enable IRQ5 (T1)! 




P 0016 


9F 






19 




EI 






P 0017 


E6 


F1 


4F 


20 
21 
22 
23 
24 
25 
26 
27 
28 




LD 


TMR,#%(2)01001111 

!bit 6-7: Tout controlled 

by TO; 
bit 4-5: Tin mode is ext. 

clock input; 
bit 3: enable T1 ; 
bit 2: load T1; 
bit 1: enable TO; 
bit 0: load TO ! 




P 001A 


AF 






29 




RET 






P 001B 








30 


END 


TIMER 16 












31 


END 


TIMER3 






ERRORS 














ASSEMBLY COMPLETE 












11 instructiom 
















27 bytes 


















26.5 i^ 

















7.4.4 Clock Monitor. 1\ and Tin may Be used 
to monitor a clock line (in a diskette drive, for 
example) and generate an interrupt request 
when a clock pulse is missed. To accomplish 
this, the clock line to be monitored is wired to 
P3i (Tin). Tin should be programmed as a 
retriggerable input to 1\, such that each fall- 
ing edge on Tin will cause Ti to reload and 
continue counting. If Ti is programmed to 
time-out after an interval of one-and-a-half 
times the clock period being monitored, Ti 
will time-out and generate interrupt request 
IRQ5 only if a clock pulse is missed. 



The following module illustrates the pro- 
cedure for initializing Ti and Tin 
(MONltOR_INIT) to monitor a clock with a 
period of 2 ixs>. XTAL = 8 MHz is assumed. 
Note that this example selects single-pass 
rather than continuous mode for Ti. This is to 
prevent a continuous stream of IRQ5 interrupt 
requests in the event that the monitored clock 
fails completely. Rather, the interrupt service 

routine (CLK ERR) is left with the choice of 

whether or not to re-enable the monitoring. 
Also shown is the Ti interrupt vector (IRQ 5). 



Z8ASM 




2.0 








LOC 


OBJ 


CODE 


STMT SOURCE STATEMENT 










1 


TIMER4 MODULE 










2 


$SECTION PROGRAM 








3 


GLOBAL 










4 


!IRQ5 interrupt 


vector! 








5 


$ABS 


10 


,P 0000 


0015' 


6' 
7 
8 


IRQ_5 ARRAY 


[1 WORD] := [CLK_ERR] 








$REL 




P OOOC 






9 
10 


MONITOR INIT 
ENTRY 


PROCEDURE 


P 0000 


E6 


F3 04 


11 
12 
13 
14 


.LD 


PRE1,#%(2)00000100 

!bit 2-7: prescaler = 1; 
bit 1: external clock; 
bit 0: single-pass mode! 


P 0003 


E6 


F7 00 


15 


LD 


P3M,//00 !bit 5: let P36 be Tout! 


P 0006 


£6 


F2 03 


16 
17 


LD 


T1,#3 !T1 load register, 
= 1.5 * 2 usee ! 
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P 0009 


8F 






18 






DI 


Counter 


P OOOA 


56 


FB 


3B' 


19 






AND IMR,#%(2)00111011 Idisable IRQ2 (Tin)! 


Functions 


P OOOD 
P 0010 


46 
9F 


FB 


20 


20 
21 






OR IMR,#%(2)00100000 !enable IRQ5 (T1)! 
EI 


(Continued) 










22 










P 0011 


E6 


F1 


38 


23 
24 
25 
26 






LD TMR,#%(2)001 1,1000 

!bit 4-5: Tin mode is 

retrig. input; 
bit 3: enable T1 ! 




P 0014 


AF 






27 






RET 




P 0015 








28 
29 
30 


END 




MONITOR_INIT 




P 0015 








31 


CLK_ 


ERR 


PROCEDURE 












32 


ENTRY 














33 






!...! ihandle the missed clock! 












34 


















35 


!if 


clock monitoring should continue...! 




P 0015 


46 


F1 


08 


36 
37 






OR TMR,#%(2)00001000 

!bit 3: enable T1 ! 




P 0018 


BF 






38 






IRET 




P 0019 








39 
40 


END 
END 




CLK_ERR 
TIMER4 




ERRORS 














ASSEMBLY COMPLETE 












MONITOR_INIT: 










CLK_ERR: 




9 instructions 










2 + instructions 




21 bytes 












4 + hytes 




21.5 ns 














18.5 + US incJuding interrupt response time 



SECTION 

8 



I/O Functions 

The Z8 provides 32 I/O lines mapped into 
registers 0-3 of the internal register file. Each 
nibble of port is individually programmable 
as input, output, or address/data lines 
(A15-A12, All -As). Port 1 is programmable as 
a single entity to provide input, output, or 
address/data lines (AD7-AD0). The operating 
modes for the bits of Ports and 1 are selected 
by control register POIM (%F8). Selection of 
I/O lines as address/data lines supports access 
to external program and data memory; this is 
discussed in Section 3. Each bit of Port 2 is 
individually programmable as an input or an 



Function 


Bit 


Signal 




P3i 


DAV2/RDY2 




P32 


DAVO/RDYO 


Handshake 


P33 


DAVl/RDYl 




P34 


RDYl/DAVl 




P35 


RDYO/DAVO 




P36 


RDY2/nAV2 



Interrupt 
Request 



Counter/ 
Timer 

Data Memory 

Select 

Status Out' 

Serial I/O 



'P3o 
P3l 
P32 

.P33 

P3l 
P3fi 



P34 

[P3o 
|P37 



IRQ3 
IRQ2 
IRQO 
IRQl 

Tin 
Tout 



DM 

Serial In 
Serial Out 



Table 4. Port 3 Special Functions 



output bit. Port 2 bits programmed as outputs 
may also be programmed (via bit of P3M) to 
all have active pull-ups or all be open-drain 
(active pull-ups inhibited). In Port 3, four bits 
(P3o-P33) are fixed as inputs, and four bits 
(P34-P37) are fixed as outputs, but their func- 
tions are programmable. Special functions pro- 
vided by Port 3 bits are listed in Table 4. Use 
of the Data Memory select output is discussed 
, in Section 3; uses of Tjn and ToUT are dis- 
cussed in Section 7. 

8.1 Asynchronous Receiver/ Transmitter 
Operation. Full-duplex, serial asynchronous 
receiver/transmitter operation is provided by 
the Z8 via P37 (output) and P3o (input) in con- 
junction with control register SIO (%F0), 
which is actually two registers: receiver buffer 
and transmitter buffer. Counter/Timer Tq pro- 
vides the clock for control of the bit rate. 

The Z8 always receives and transmits eight 
bits between start and stop bits. However, if 
parity is enabled, the eighth bit (D7) is 
replaced by the odd-parity bit when trans- 
mitted and a parity-error flag ( = 1 if error) 
when received. Table 5 illustrates the state of 
the parity bit/parity error flag during serial 
I/O with parity enabled. ' • . 

Although the Z8 directly supports either odd 
parity or no parity for serial I/O operation, 
even parity may also be provided with addi- 
tional software support. To receive and 
transmit with even parity, the Z8 should be 
configured for serial I/O with odd parity 
disabled. The Z8 software must calculate parity 
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Character Loaded 


Transmitted To 


Received From 


Character 




Functions 


Into SIO 


Serial Line 


Serial Line 


Transferred To SIO 


Note* 


(Continued) 


11000011 


01000011 


01000011 


01000011 


no error 




11000011 


01000011 


01000111 


11000111 


error 




01111000 


11111000 


11111000 


01111000 


no error 




01111000 


11111000 


01111000 


11111000 


error 



Table 5. Serial I/O With Odd Parity 



* Left-most bit is D7 



and modify the eighth bit prior to the load of a 
character into SIO and then modify a parity 
error flag following the load of a character 
from SIO. All other processing required for 
serial I/O (e.g. buffer management, error 
handling, etc.) is the same as that for odd 
parity operations. 

To configure the Z8 for Serial I/O, it is 
necessary to: 

■ Enable P3o and PS? for serial I/O and select 
parity, 

■ Set up To for the desired bit rate, 

■ Configure IRQ3 and IRQ4 for polled or 
automatic interrupt mode, 

■ Load and enable Tq. " 

To enable P3o and PSy for serial I/O, bit 6 of 
P3M (R247) is set. To enable odd parity, bit 7 
of P3M is set; to disable it, the bit is reset. For 
example, the instruction 

LD P3M,#%40 

will enable serial I/O, but disable parity. The 
instruction 

LD P3M,#%C0 

will enable serial I/O, and enable odd parity. 

In the following discussions, bit rate refers to 
all transmitted bits, including start, stop, and 
parity (if enabled). The serial bit rate is given 
by the equation: 

input clock frequency 

bit rate = . 

(2 X 4 X Tq prescaler x Tq counter x 16) 

The final divide-by- 16 is incurred for serial 
communications, since in this mode Tq runs at 
16 times the bit rate in order to synchronize 
the data stream. To configure the Z8 for a 
specific bit rate, appropriate values must first 
be selected for Tq prescaler and Tq counter by 
the above equation; these values are then pro- 
grammed into registers Tq (%F4) and PREO 
(%F5) respectively. Note that PREO also con- 
trols the continuous vs. single-pass mode for 
Tq; continuous mode should be selected for 
serial I/O, For example, given an input clock 
frequency of 7.3728 MHz and a selected bit 
rate of 9600 bits per second, the equation is 



satisfied by Tq counter = 2 and prescaler = 3. 
The following code sequence will configure the 
To counter and To prescaler registers: 

LD To,#2 !To counter = 2! 
LD PRE0,#%(2)00001101 

!bit 2-7: prescaler = ,3; bit 0: 
continuous mode! 

Interrupt request 3 (IRQ3) is generated 
whenever a character is transferred into the 
receive buffer; interrupt request 4 (IRQ4) is 
generated whenever a character is transferred 
out of the transmit buffer. Before accepting 
such interrupt requests, the Interrupt Mask, 
Request, and Priority Registers (IMR, IRQ, and 
IPR) must be programmed to configure the 
mode of interrupt response. The section on 
Interrupt Processing provides a discussion of 
interrupt configurations. 

To load and enable Tq, set bits and 1 of 
the timer mode register (TMR) via an instruc- 
tion such as 

OR TMR,#%03 

This will cause the Tq prescaler and counter 
registers (PREO and Tq) to be transferred, to the 
To prescaler and counter. In addition, To is 
enabled to count, and serial I/O operations 
will commence. 

Characters to be output to the serial line 
should be written to serial I/O register SIO 
(%F0). IRQ4 will be generated when all bits 
have been transferred out. 

Characters input from the serial line may be 
read from SIO. IRQ3 will be generated when a 
full character has been transferred into SIO. 

The following module illustrates the receipt 
of a character and its immediate echo back to 
the serial line. It is assumed that the Z8 has 
been configured for serial I/O as described 
above, with IRQ3 (receive) enabled to interrupt, 
and IRQ4 (transmit) configured to be polled. 
The received character is stored in a circular 
buffer in register memory from address %42 to 
%5F. Register %41 contains the address of 
the next available buffer position and should 
have been initialized by some earlier routine 
to #%42. 
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Z8ASM 




2,0 










Functions 


LOG 


OBJ 


CODE 


STMT SOURCE STATEMENT 




(Continued) 










1 
2 
3 
4 
5 
6 
7 
8 
9 


SERIAL_I0 MODULE 

CONSTANT 
next_addr := , %41 
start := %42 
length := %^E 

$SECTION PROGRAM 

GLOBAL 

•IRQ3 vector! 

$ABS 6 






P 0006 


0000' 




10 
11 
12 


IRQ^3 ARRAY [1 WORD] := [GET. 


.CHARACTER] 












$REL 






P 0000 








13 
14 


GET_CHARACTER PROCEDURE 


ENTRY 












15 


!Serial I/O receive interrupt service! 












16 


!Echo received character and wait for 












17 


echo completion! 






P 0000 


E4 


FO 


FO 


18 
19 
20 


Id . SIO,SIO 
!save it in circular buffer! 


!echo! 




P 0003 


F5 


FO 


41 


21 


Id @next_addr,SIO 


!save in buffer! 




P 0006 


20 


41 




22 


inc next_addr 


!point to next position! 




P 0008 


A6 


41 


60 


23 


cp next_addr, #start+length 












24 




!wrap-around yet?! 




P OOOB 


EB 


03 




25 


jr ne,echo_wait 


•no.! 




P GOOD 


E6 


41 


42 


26 


Id. next_addr, //start !yes. point to start! 












27 


!now, wait for echo complete! 














28 


echo_wait: 






P 0010 


66 


FA 


10 


29 


tern IRQ, #5510 


!transmitted yet?! 




P 0013 


EB 


FB 




30 
31 


jr nz,echo_wait 


!not yet! 




P 0015 


56 


FA 


EF 


32 


and IRQ,#%EF 


!clear IRQ4! 




P 0018 


BF 






33 


IRET 


! return from interrupt! 




P 0019 








34 
35 


END GET CHARACTER 
END SERIAL_IO 






ERRORS 












ASSEMBLY COMPLETE 










10 instructions 














25 bytes 
















35.5 fis 4 


5.5 


(IS for each additional pass through the echo_wait hop. 






including interrupt response time 





8.2 Automatic Bit Rate Detection. In a typical 
system, where serial communication is 
required (e.g. system with a terminal), the 
desired bit rate is either user-selectable via a 
switch bank or non variable and ''hard- coded" 
in the software. As an alternate method of bit- 
rate detection, it is possible to automatically 
determine the bit rate of serial data received 
by measuring the length of a start bit. The 
advantage of this method is that it places no 
requirements on the hardware design for this 
function and provides a convenient (automatic) 
operator interface. 

In the technique described here, the serial 
channel of the Z8 is initialized to expect a bit 
rate of 19,200 bits per second. The number of 
bits (n) received through Port pin P30 for each 
bit transmitted is expressed by 

n = 19,200/b 

where b = transmission bit rate. For example, 
if the transmission bit rate were 1200 bits per 
second, each incoming bit would appear to the 
receiving serial line as 19,200/1200 or 16 bits. 
The following example is capable of disting- 



uishing between the bit rates shown in Table 6 
and assumes an input clock frequency of 
7.3728 MHz, a Tq prescaler of 3, and serial I/O 
enabled with parity disabled. This example 
requires that a character with its low order 
bit = 1 (such as a carriage return) be sent to 
the serial channel. The start bit of this 
character can be measured by counting the 
number of zero bits collected before the low 
order 1 bit. The number of zero bits actually 
collected into data bits by the serial channel is 
less than n (as given in the above equation), 
due to the detection of start and stop bits. 
Figure 4 illustrates the collection (at 19,200 



1 



ST I DO [ P1 I D2 [ D3 I D4 I PS I D6 I D7 I SP j ST I DO I PI I D2 [ D3 1 1 



J" 



-1 BIT TIME AT 1,200 BITS PER SECOND- 



ST = START BIT SP = STOP BIT Dn = DATA BIT n 



Figure 4. Collection of a Start Bit Transmitted at 
at 19,200 BPS 
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8. I/O 




Number of Bits Received 


Number of Bits Collected . 






Functions 


Bit Rate 


Per Bit Transmitted 


as 


Data Bits 


To 


Counter 


(Continued) 






dec 


binary 


dec 


binary 




19200 


1 





00000000 


1 


00000001 




9600 


2 


1 


00000001 


2 


00000010 




4800 


4 


3 


00000011 


4 


00000100 




2400 


8 


7 


00000111 


8 


00001000 




1200 


16 


13 


00001101 


16 


00010000 




600 


32 


25 


00011001 


32 


00100000 




300 


64 


49 


00110001 


64 


01000000 




150 


128 


97 


01100001 


128 


10000000 



Table 6. Inputs to the Automatic Bit Rate Detection Algorithm 



bits per second) of a zero bit transmitted to the 
Z8 at 1,200 bits per second. Notice that only 13 
of the 16 zero bits received are collected as 
data bits. 

Once the number of zero bits in the start bit 
has been collected and counted, it remains to 
translate this count into the appropriate Tq 
counter value and program that value into Tq 
(%F4). The patterns shown in the two binary 
columns of Table 6 are utilized in the 
algorithm for this translation. 

As a final step, if incoming data is to com- 
mence immediately, it is advisable to wait until 
the remainder of the current "elongated" 



character has been received, thus "flushing" 
the serial line. This can be accomplished 
either via a software loop, or by programming 
Ti to generate an interrupt reguest after 
the appropriate amount of time has elapsed. 
Since a character is corriposed of eight bits 
plus a minimum of one stop bit following the 
start bit, the length of time to delay may be 
expressed as 

(9 X n)/b 

where n and b are as defined above. The 
following module illustrates a sample program 
for automatic bit rate detection. 



Z8ASM 




2.0 














LOG 


OBJ 


CODE 


STMT SOURCE STATEMENT 












1 


bit_rate 


MODULE 












2 


EXTERNAL 














3 


DELAY 


PROCEDURE 












4 


GLOBAL 








P 0000 








5 


main 


PROCEDURE 












6 




ENTRY 






P 0000 


8F 






7 




di 




Idisable interrupts! 


P 0001 


56 


FB 


77 


8 




and 


IMR,#%77 


!IRQ3 polled mode! 


P 0004 


56 


FA 


F7 


9 




and 


IRQ,#%F7 


!clear IRQ3! 


P 0007 


E6 


F7 


40 


10 




Id 


P3M,#%40 


!enable serial I/O! 


P OOOA 


E6 


F4 


01 


11 




Id 


T0,#1 




P OOOD 


E6 


F5 


OD 


12 




Id 


PRE0,#(3 SHL 2) + l !bit rate = 19,200.; 










13 








continuous count mode! 


P 0010 


BO 


EO 




14 




clr 


RO 


!init. zero byte counter! 


P 0012 


E6 


F1 


03 


15 
16 
17 




Id 


TMR,#3 


!load and enable TO! 










Icollect input 


bytes by counting the number of null 










18 


charac 


ters received. Stop 


1 when non-zero byte received! 










19 


collect 


: 






P 0015 


76 


FA 


08 


20 




TM 


IRQ, #5508 


!character received?! 


P 0018 


6B 


FB 




21 




jr 


z, collect 


!not yet! 


P 001A 


18 


FO 




22 




Id 


R1,SI0 


!get the character! 


P OOIC 


56 


FA 


FT 


23, 




and 


im.HFl 


!clear interrupt request! 


P 001F 


IE 






24 




inc 


R1 


!compare to ... ! 


P 0020 


1A 


05 




25 




djnz 


* Rl , bitloop 


!...(in 3 bytes of code)! 


P 0022 


06 


EO 


08 


26 




add 


RO , #8 


!update count of bits! 


P 0025 


8B 


EE 




27 
28 
29 


bitloop 


Jr 


collect 


!add in zero bits from low 
end of 1st non-zero byte! 


P 0027 


EO 


El 




30 




RR 


Rl 




P 0029 


7B 


03 




31 




jr 


c,count_done 


P 002B 


OE 






32 




inc 


RO 




P 002C 


8B 


F9 




33 

34 




jr 


bitloop 












35 


!R0 has 


number 


of zero bits 


collected! 










36 


Itransli 


at^ RO ' 


bo the appropriate TO counter value! 










37 


count_done: 




!R0 has count of zero bits! 


P 002E 


1C 


07 




38 




Id 


R1,,#7 




P 0030 


2C 


80 




39 




Id 


R2,#%80 


!R2 will have TO counter value! 


P 0032 


90 


EO 




40 
41 




RL 


RO 




P 0034 


90 


EO 




42 


loop: 


RL 


RO 
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8. I/O 
Functions 

(Continued) 



P 0036 7B 04 

P 0038 EO E2 

P 003A 1A F8 

P^003C 29 F4 



P 003E D6 0000* 
P 0041 56 FA F7 
P 0044 



43 , jr c,done 

44 RR R2 

45 djnz r1,loop 
46 

47 done: Id T0,R2 !load value for detected 

48 bit rate! 

49 IDelay long enough to clear serial line of bit stream! 

50 call DELAY 

51 Jclear receive interrupt request! 

52 and IRQ,#^F7 
53 

54 END main 

55 END bit_rate 



ERRORS 
ASSEMBLY COMPLETE 



30 instructions 

68 bytes 

Execution time is variable based on transmission bit rate. 



8.3 Port Handshake. Each of Ports 0, 1 and 2 
may be programmed to function under input or 
output handshake control. Table 7 defines the 
port bits used for the handshaking and the 
mode bit settings required to select handshak- 
ing. To input data under handshake control, 
the Z 8 should read the input port when the 
DAV input goes Lov\r (signifying that data is 
available from the attached device) . To output 
data under handshake control, the Z8 should 
write the output port when the RDY input goes 
Low (signifying that, the previously output data 
has been accepted by the attached device) . 
Interrupt requests IRQO, IRQl, and IRQ2 are 
generated by the falling edge of the handshake 
signal input to the Z8 for Port 0, Port 1 , and 
Port 2 respectively. Port handshake operations 
may therefore be processed under interrupt 
control. 

Consider a system that requires communica- 
tion of eight parallel bits of data under hand- 
shake control from the Z8 to a peripheral 
device and that Port 2 is selected as the output 
port. The following assembly code illustrates 
the proper sequence for initializing Port 2 for 
output handshake. 



CLR P2M IPort 2 mode register: all Port 

2 bits are outputs! 
OR Q/o03,#%4 

. !set DAV2: data not available! 
LD P3M,#%20 

! Port 3 mode register: enable 
Port 2 handshake! 

LD %02,DATA 

! output first data byte; DAV2 
will be cleared by the Z8 to 
indicate data available to 
the peripheral device! 
Note that following the initialization of the out- 
put sequence, the software outputs the first 
data byte without regard to the state of the 
RDY2 input; the Z8 will automatically hold 
DAV2 High until the RDY2 input is High. The 
peripheral device should force the Z8 RDY2 
input line Low after it has latched the data in 
response to a Low on DAV2. The Low o n RD Y2 
will cause the Z8 to automatically force DAV2 
High until the next byte is output. Subsequent 
bytes should be output in response to interrupt 
request IRQ2 (caused by the High-to-Low tran- 
sition on RDY2) in either a polled or an 
enabled interrupt mode. 



Porto 



Portl 



Port 2 



Input handshake lines 
Output handshake lines 



/P32 = DAV 
|P35 = RDY 

P32 = RDY 
PSs = DA7 



P33 = rav 

P34 = RDY 

P33 = RDY 
P34 = UM 



P3i = UKV 
P36 = RDY 

P3i = RDY 
P36 = HAT 



To select input handshake: 



To select output handshake: 



To enable handshake: 



set bit 6 & reset bit 7 of 
POIM (program high 
nibble as input) 

[reset bits 6, 7 of POIM 
i (program high nibble as 
[output), 

set bit 5 of Port 3 (P35); 
set bit 2 of P3M 



set bit 3 & reset bit 4 of 
POIM (program byte as 
input) 

reset bits 3, 4 of POIM 
(program byte as output) 

set bit 4 of Port 3 (P34); 
set bits 3, 4 of P3M , 



set bit 7 of P2M 

(program high bit as input) 

reset bit 7 of P2M 
(program high bit as output) 



set bit 6 of Port 3 (P36); 
set bit 5 of P3M 



Table 7. Port Handshake Selection 
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SECTION Arithmetic Routines cessed one nibble at a time from left to right, 

O This section gives examples of the arithmetic beginning with the high-order nibble of the 

and rotate instructions for use in multiplica- lower memory address. %30 is added to each 

tion, division, conversion, and BCD arithmetic nibble if it is in the range to 9; otherwise 

algorithms. %37 is added. In this way, %0 is converted to 



9.1 Binary to Hex ASCII. The following 



%30, %1 to %31, . . . %A to %41, . . . %F to 



module illustrates the use of the ADD and °/°^6. Figure 5 illustrates the conversion of RRO 

SWAP arithmetic instructions in the conversion (contents = %F2BE) to its hex ASCII 

of a 16-bit binary number to its hexadecimal equivalent; the destination buffer is pointed to 

ASCII representation. The l6-bit number is "^ nn4. 

viewed as a string of four 'nibbles and is pro- 

BIT D7 43 Do D7 43 Do 





D7 




4 3 


D( 


) D7 43 


Do D7 43 Do D7 43 Do 


RR4 ■—' 


c 


4 


1 


» 1 


1 3 1 a 


1 1 . 1 2 1 1 4 1 s 1 












Figure 5. Conversion of (RRO) to Hex ASCII 


Z8ASM 


2.99 




INTERNAL RELEASE 




LOC 


OBJ 


CODE 


STMT 


SOURCE STATEMENT 










1 


ARITH MODULE 












2 


GLOBAL 




P 0000 








3 
4 


BINASC PROCEDURE 










5 


Purpose = 


To convert a 16-bit binary 










6 
7 
8 




number to Hex ASCII 










Input = 


RRO = 16-bit binary number. 










9 




RR4 = pointer to destination 










10 
11 
12 




buffer in external memory. 










Output = 


Resulting ASCII string (4 bytes) 










13 




in destination buffer. 










14 




RR4 incremented by 4 . 










15 




R0,R2.R6 destroyed. 










16 


K«««««if««««»«««««««««««««««»««««««««««««#«««««««M^«««! 










17 


ENTRY 












18 






P 0000 


6C 


04 




19 


Id 


R6,#7o04 !nibble count! 


P 0002 


FO 


EO 




20 


again; SWAP 


RO Uook at next nibble! 


P 0004 


28 


EO 




21 


Id 


R2,R0 


P 0006 


56 


E2 


OF 


22 


and 


R2,#7»0F 'isolate 4 bits! 










23 


Iconvert to ASCII : R2 + #%30 if RO in range to 9 










24 


e 


dse R2 + #7o37 (in range OA to OF) 










25 


I 




P .0009 


06 


E2 


30 


26 


ADD 


R2,#%30 


P OOOC 


A6 


E2 


3A 


27 


cp 


R2,#7o3A 


P OOOF 


7B 


03 




28 


jr 


ult,skip 


P 0011 


06 


E2 


07 


29 


ADD 


R2,//7o07 


P 0014 


92 


24 




30 


skip: Ide 


@RR4,R2 !save ASCII in buffer! 


P 0016 


AO 


E4 




31 
32 


incw 


RR4 !point to next 

buffer position! 


P 0018 


A6 


E6 


03 


33 


cp 


R6,#7o03 !time for second byte?! 


P 001B 


EB 


02 




34 


jr 


ne , same_by te !no. ! 


P 001D 


08 


El 




35 
36 


Id 
same_byte: 


R0,R1 !2nd byte! 


P 001F 


6A 


El 




37 


djnz 


R6, again 


P 0021 


AF 






38 


ret 




P 0022 








39 
40 


END BINASC 
END ARITH 




errors 










Assembly complete 








15 instructions 












34 bytes 














120.5 lis 1 


(average) 
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9. Arithmetic 9.2 BCD Addition. The following module illus- 
Routines trates the use of the add with- carry (ADC) and 

(Continued) decimal adjust (DA) instructions for the addi- 
tion of two unsigned BCD strings of equal 
length. Within a BCD string, each nibble 
represents a decimal digit (0-9). Two such 
digits are packed per byte with the most 



significant digit in bits 7-4. Bytes within a 
BCD string are arranged in memory with the 
most significant digits stored in the lowest 
memory location. Figure 6 illustrates the 
representation of 5970 in a 6-digit BCD string, 
starting in register %33. 



4 3 Do 0/ 



Figure 6. Unsigned BCD Representation 



Z8ASM 




2.0 








LOG 


OBJ 


CODE 


STMT SOURCE STATEMENT 










1 


ARITH MODULE 










2 


CONSTANT 










3 


BCD_SRC := R1 










4 


BCD_DST := RO 










5 


BCD_LEN := R2 










6 


GLOBAL 




P 0000 






7 
8 


BCDADD PROCEDURE . 

1 ««««»«»»«««»««««««««««»«««»««««««««««««««»« «««x««xx«« 








9 


Purpose = 


To add two packed BCD strings of 








10 




equal length. 








11 




dst < — dst + src / 








12 












13 


Input = 


RO = pointer to dst BCD string. 








14 




R1 = polluter to src BCD string. 








15 




R2 = byte count in BCD string 








16 




(digit count = (R2)*2 ). 








17 












18 


Output = 


BCD string pointed to by RO is 








19 




the sum. 








20 




Carry FLAG = 1 if overflow. 








21 




RO , R1 as on entry. 








22 




R2 = 








23 


««««««K««X«««»««««»««««»««««««««»««»««««««««j(««»«««««| 








24 


ENTRY 










25 






P 0000 


02 


12 


26 


-add 


BCD_SRC,BCD_LEN Istart at least... ! 


P 0002 


02 


02 


27 


add 


BCD_DST,BCD_LEN '.significant digits! 


P 0004 


CF 




28 
29 


rcf 
add_again: 


Icarry = 0! 


P 0005 


00 


El 


30 
31 


dec 


BCD_SRC Ipoint to next two 
src digits! 


P 0007 


00 


EO 


32 
33 


dec 


BCD_'DST -! point to next two 
dst digits! 


P 0009 


E3 


31 


34 


Id 


R3,@BCD_SRC !get src digits! 


P OOOB 


13 


30 


35 


ADC- 


R3,§BCD_DST !add dst digits! 


P OOOD 


40 


E3 


36 


DA 


R3 !decimal adjust! 


P OOOF 


F3 


03 


37 


Id 


@BCD_DST,R3 !move to dst! 


P 0011 


2A 


F2 


38 
39 


djnz 


BCD_LEN,add_again !loop for next 
digits! 


P 0013 


AF 




40 
41 


ret 


!all done! 


P 0014 






42 
43 


END BCDADD 
END ARITH 




ERRORS 








ASSEMBLY COMPLETE 









11 instructions 
20 bytes 

Execution time is a function of the number of bytes (n) iti input BCD string: 
20 IIS -^ 12.5 (n- 1) lus 
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9. Arithmetic 9.3 Multiply. The following module illustrates 
Routines an efficient algorithm for the multiplication of 

(Continued) two unsigned 8-bit values, resulting in a 16-bit 
product. The algorithm repetitively shifts the 
multiplicand right (using RRC), with the low- 
order bit being shifted out (into' the carry flag). 
If a one is shifted out, the multiplier is added 



to the high-order byte of the partial product. 
As the high-order bits of the multiplicand are 
vacated by the shift, the resulting partial- 
product bits are rotated in. Thus, the multipli- 
cand and the low byte of the product occupy 
the same byte, which saves register space, 
code, and execution time. 



Z8ASM 




2.99 


INTERNAL RELEASE 


LOC 


OBJ 


CODE 


STMT 

1 
2 
3 
4 
5 
6 
7 


SOURCE STATEMENT 

ARITH MODULE 

CONSTANT 
MULTIPLIER := Rl 
PRODUCT_LO := R3 
PRODUCT.HI := R2 
COUNT := RO 

GLOBAL 


P 0000 






8 
9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 


MULT PROCEDURE 

Purpose = To perform an 8-blt by 8-bit unsigned 
binary multiplication. 

Input = Rl = multiplier 

R3 = multiplicand 

Output = RR2 = product 
RO destroyed 

ENTRY 


P 0000 


OC 


09 


20 


Id COUNT, #9 !8 BITS + 1! 


P 0002 


BO 


E2 


21 


clr PRODUCT_HI UNIT HIGH RESULT BYTE! 


P 0004 


CF 




22 


RCF 'CARRY =0! 


P 0005 


CO 


E2 


23 


LOOP: RRC PRODUCT HI 


P 0007 


CO 


E3 


24 


RRC PRODUCT.LO 


P 0009 


FB 


02 


25 


jr NC,NEXT 


P OOOB 


02 


21 


26 


ADD PRODUCT HI, MULTIPLIER 


P OOOD 


OA 


F6 


27 


NEXT: djnz COUNT, LOOP 


P OOOF 


AF 




28 


ret 


P 0010 






29 
30 


END MULT 
END ARITH 


errors 






Assembly complete 






9 instructions 








16 bytes 










92.5 us (average) 







9.4 Divide. The following module illustrates 
an efficient algorithm for the division of a 
16-bit unsigned value by an 8-bit unsigned 
value, resulting in an 8-bit unsigned quotient. 
The algorithm repetitively shifts the dividend 
left (via RLC). If the high-order bit shifted out 
is a one or if the resulting high-order dividend 
byte is greater than or equal to the divisor, the 



divisor is subtracted from the high byte of the 
dividend. As the low-order bits of the dividend 
are vacated by the shift left, the resulting 
partial-quotient bits are rotated in. Thus, the 
quotient and the low byte of the dividend 
occupy the same byte, which saves register 
space, code, and execution time. 
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9. Arithmetic 


Z8ASM 




2,0 








Routines 


LOC 


OBJ 


CODE 


STMT SOURCE STATEMENT 


(Continued) 








1 


ARITH 


MODULE 










2 


CONSTANT 










3 


COUNT 




RO 










4 


DIVISOR 


= R1 










5 


DIVIDEND^HI 


R2 










6 


DIVIDEND_L0 


R3 










7 


GLOBAL 






P 0000 






8 


DIVIDE 


PROCEDURE 










9 


!««X««««««»««««««J(«X«««««»««X«4f««««««««««««X«««««««X«« 










10 


Purpose- = To perform a 16-bit by 8-bit unsigned 










11 




binary division. 










12 














13 


Input 


R1 = 8-bit divisor 










14 




RR2 = 16-bit dividend 










15 














16 


Output = R3 = 8-bit quotient 










17 




R2 = 8-bit remainder 










18 




Carry flag = 1 if overflow 










19 




= if no overflow 










20 


«««X«««««««««««««X«««««««««««««««««««««K«««««««««««X«! 










21 


ENTRY 






P 0000 


OC 


08 


22 
23 
24 


ICHECK 


Id COUNT, #8 !LOOP COUNTER! 
IF RESULT WILL FIT IN 8 BITS! 




P 0002 
P 0004 


A2 


12 


25 




cp DIVISOR, DIVIDEND HI 




BB 


02 


26 




jr UGT,LOOP !CARRY = (FOR RLC) ! 










27 


.'WON'T 


FIT. OVERFLOW! 




P 0006 


DF 




28 




SCF ! CARRY = 1! 




P 0007 


AF 




29 
30 
31 


LOOP: 


ret 
!RESULT WILL FIT. GO AHEAD WITH DIVISION! 




P 0008 


10 


E3 


32 




RLC DIVIDEND^LO ! DIVIDEND * 2! 




P OOOA 


10 


E2 


33 




RLC DIVIDEND_HI 




P OOOC 


7B 


04 


34 




jr c,subt 




P OOOE 


A2 


12 


35 




cp DIVISOR, DIVIDEND HI 




P 0010 


BB 


03 


36 




jr UGT,next !CARRY = 0! 




P 0012 


22 


21 


37 


subt: 


SUB DIVIDEND HI, DIVISOR 




P 0014 


DF 




38 




SCF !T0 BE SHIFTED INTO RESULT! 




P 0015 


OA 


F1 


39 
40 
41 


next: 
!ALL 


djnz COUNT, LOOP !no flags affected! 
DONE! 




P 0017 


10 


E3 


42 
43 




RLC DIVIDEND LO 

!CARRY = 0: no overflow! 




P 0019 


AF 




44 




ret 




P 001A 






45 
46 


END DIVIDE 
END ARITH 




ERRORS 










ASSEMBLY COMPLETE 










15 instructions 












26 bytes 














124.5 fis (average) 









SECTION 

10 



Conclusion 

This Application Note has focused on ways 
in which the Z8 microcomputer can easily yet 
effectively solve various application problems. 
In particular, the many sample routines 



illustrated in this document should aid the 
reader in using the Z8 to greater advantage. 
The major features of the Z8 have been 
described so that the user can continue to 
expand and explore the ZB's repertoire of uses. 
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Z8® Subroutine Library 



C^TjMS 



Application 
Note 



April 1982 



INTRODUCTION 

This application note describes a preprogrammed 
Z8601 MCU that contains a bootstrap to external 
program memory and a collection of general-purpose 
subroutines. Routines in this application note 
can be implemented with a Z8 Protopack and a 2716 
EPROM programmed with the bootstrap and subroutine 
library. 

In a system, the user's software resides in 
external memory beginning at hexidecimal address 
0800. This software can use any of the 



subroutines in the library wherever appropriate 
for a given application. This application example 
makes certain assumptions about the environment; 
the reader should exercise caution when copying 
these programs for other cases. 

Following RESET, software within the subroutine 
library is executed to initialize the control 
registers (Table 1). The control register 
selections can be subsequently modified by the 
user's program (for example, to use only 12 bits 
of Ports and 1 for addressing external memory) . 
Following control register initialization, an EI 



Table 1. Control Register Initialization 



Qmtrol 

Hame 


Register 
Address 


Initial Value 


Meaning 


TMR 


F1H 


OOH 


TO and T1 disabled 


P2M 


F6H 


FFH 


P2o-P27 : inputs 


/ P3M 


F7H 


10H 


P2 pull-ups open drain; 



P01M 



F8H 



D7H 



P3q-P33 : inputs; 
P35-P37 : outputs; 
P34 : DM 

PI0-PI7 : AD0-AD7; 
PO0-PO7 : Ag-A^5; 
normal memory timing; 
internal stack 



IRQ 


FAH 


OOH 


no interrupt requests 


IMR 


FBH 


OOH 


no interrupts enabled 


RP 


FDH 


OOH 


working register file 
OOH-OFH 


SPL 


FFH 


65H 


1st byte of stack is 
register 64H 
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instruction is executed to enable interrupt 
processing, and a jump instruction is executed to 
transfer control to the user's program at location 
081 2j^. The interrupt vectors for IRQq through 
IRQ5 are rerouted to locations 0800^^ through 
08dF^, respectively, in three-byte increments, 
allowing enough room for a jump instruction to the 
appropriate interrupt service routine. That is, 
IRQq is routed to location 0800^, IRQ^ to 
0803^, IRQ2 to 0806^^, IRQ3 to 0809j^, IRQ4 to 
080%, and IRQ5 to 080?^. Figure 1 illus- 
trates the allocation of 28 memory as defined by 
this application note. 



The subroutines available to the user are refer- 
enced by a jump table beginning at location 
001&H. Entry to a subroutine is made via the jump 
table. The 32 subroutines provided in the library 
are grouped into six functional classifications. 
These classifications are described below, each 
with a brief overview of the functions provided by 
each category. Table 2 defines one set of entry 
addresses for each subroutine in the library. 

• Binary Arithmetic: Multiplication and division 
of unsigned 8- and 16-bit quantities. 

• BCD Arithmetic: Addition and subtraction of 
variable-precision floating-point BCD values. 



• Conversion Algorithms: BCD to and from decimal 
ASCII, binary to and from decimal ASCII, binary 
to and from hex ASCII. 

• Bit Manipulations: Packs selected bits into 
the low-order bits of a byte, and optionally 
uses the result as an index into a jump table. 

• Serial I/O: Inputs bytes under vectored inter- 
rupt control, outputs bytes under polled inte- 
rrupt control. Options provided include: 

odd or even parity 

BREAK detection 

echo 

input editing (backspace, delete) 

auto line feed 

• Timer/Counter: Maintains a time-of-day clock 
with a variable number of ticks per second, 
generates an interrupt after a specified delay, 
generates variable width, variable frequency 
pulse output. 

The listings in the "Canned Subroutine Library" 
provide a specification block prior to each sub- 
routine, explain the subroutine's purpose, lists 
the input and output parameters, and gives pertin- 
ent notes concerning the subroutines. The follow- 
ing notes provide additional information on data 
formats and algorithms used by the subroutines. 



EXTERNAL DATA 



CONTROL 
REGISTERS 


FFFF 

0812 
0811 

0600 
07FF 

0000 


USER 
DEFINED 

START 


UNIMPLEMENTED 


1. 


2. 


3. 


STACK 


USER 
DEFINED . 


INTERRUPT VECTORS 
<3 BYTE/IRQx) 


INTERNAL 
SUBROUTINES 


I/O PORTS 



REGISTERS USED BY SUBROUTINES: 

1. USED BY MOST ROUTINES 

2. USED BY SERIAL ROUTINES ONLY 

3. USED BY TIMER/COUNTER ROUTINES ONLY 



Figure 1« "ROMLess Z8" Subroutine Library Meaory Usage Hap 
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1« Although the user is free to modify the condi- 
tions selected in the Port 3 Mode register 
(P3M, F7^)| P3M is a write-only register. 
This subroutine library maintains an image of 

P3M in its register P3M save (TF^). If 

software outside of the subroutine package is 
to modify P3M, it should reference and modify 

P3M save prior to modification of P3M. For 

example, to select P32/P35 for handshake, the 
following instruction sequence could be used: 

OR P3M_save, #04H 
LD P3M, P3M save 



Digits are packed two per byte with the most- 
significant digit in the high-order nibble of 
byte 1 and the least-significant digit in the 
low-order nibble of byte n. Byte is organ- 
ized as two fields: 

Bit 7 represents sign: 
1 = negative; 
= positive. 

Bits 0-6 represent post -decimal digit count. 

For example: 



For many of the subroutines in this library, 
the location of the operands (source/destina- 
tion) is flexible between register memory, 
external memory (code/data), and the serial 
channel (if enabled). The description of each 
parameter in the specification blocks tells 
what the location options are. 

• The location designation "in reg/ext 
memory" implies that the subroutine allows 
the operand to exist in register or in 
external data memory. The address of such 
an operand is contained in the designated 
register pair. If the high byte of that 
pair is 0, the operand is in register 
memory at the address held in the low byte 
of the register pair. Otherwise, the 
operand is in external data memory 
(accessed via IDE). 



byte = 05^ = positive, with five post- 
decimal digits 

= 80^ = negative, with no post- 
decimal digits 

= 90|^ = negative, with 16 post- 
decimal digits 



A. The format of the decimal ASCII character 
string expected as input to the conversion 
routines "dascbcd" and "dascwrd" is defined 



( + 1 - ) ( <digit> ) [ ( <digit> ) ] 

in which 

( ) Parentheses mean that the enclosed 

times or can be omitted. 
[ ] Brackets denote that the enclosed 

element is optional. 



3. 



The location designation "in reg/ext/ser 
memory" implies the same considerations as 
above with one enhancement: if both bytes 
of the register pair are 0, the operand 
exists in the serial channel. In this 
case, the register pair is not modified 
(updated). For example, rather than stor- 
ing a destination ASCII string in memory, 
it might be desirable to output the string 
to the serial line. 



The BCD format supported by the following 
arithmetic and conversion routines allows rep- 
resentation of signed variable-precision BCD 
numbers. A BCD number of 2n digits is repre- 
sented in n+1 consecutive bytes, where the 
byte at the lowest memory address (byte 0) 
represents the sign and post-decimal- digit 
count, and the bytes in the n higher memory 
locations (bytes 1 through n) represent the 
magnitude of the BCD number. The address of 
byte and the value n are passed to the sub- 
routines in specified working registers. 



Table 3 illustrates how various input strings 
are interpreted by the conversion routines. 



The format of the decimal ASCII character 
string output from the conversion routine 
"bcddasc" operating on an input BCD string of 
2n digits is 

1 sign of character ( + 1 - ) 

2n-x pre-decimal digits 

1 decimal point if x does not equal 

X post-decimal digits 



6. The format of the decimal ASCII character 
string output from the conversion routine 
"wrddassc" is 

1 sign character (determined by bit 15 of 

input word) 
6 pre-decimal digits 
no decimal point 
no post-decimal digits 
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Table 2. Subroutine Entry Points 



Address 



Description 



Binary Arithmetic Routines 



001B 


divide 


001E 


div 16 


0021 


multiply 


0024 


mult 16 



16/8 unsigned binary division 
16/16 unsigned binary division 
8x8 unsigned binary multiplication 
16x16 unsigned binary multiplication 



BCD Arithmetic Routines 



0027 
002A 



bcdadd 
bcdsub 



BCD addition 
BCD subtraction 



Cdnversion Routines 



002D 


bcddasc 


0030 


dascbcd 


0033 


bcdwrd 


0036 


wrdbcd 


0039 


bythasc 


003C 


wrdhasc 


00 3F 


hascwrd 


0042 


wrddasc 


0045 


dascwrd 



BCD to decimal ASCII 

Decimal ASCII to BCD 

BCD to binary word 

Binary word to BCD 

Binary byte to hexadecimal ASCII 

Binary word to hexadecimal ASCII 

Hexadecimal ASCII to binary word 

Binary word to decimal ASCII 

Decimal ASCII to binary word 



Bit Manipulation Routines 



0048 
004B 



clb 
tmj 



Collect" bits in a byte 
Table jump under mask 



Serial Routines 



004E 


ser init 


Initialize serial I/O 


0051 


ser__input 


IRQ3 (receive) service 


0054 


ser rlin 


Read line 


0057 


ser rabs 


Read absolute 


005A 


ser break 


Transmit BREAK 


005D 


ser flush 


Flush (clear) input buffer 


0060 


ser wlin 


Write line 


0063 


ser wabs 


Write absolute 


0066 


serjwbyt 


Write byte 


0069 


ser disable 


Disable serial I/O 



Timer/Counter Routines 



006C 


tod i 


006F 


tod 


0072 


delay 


0075 


pulse_ 


0078 


pulse 



Initialize for time-of-day clock 
Time-of-day IRQ service 
Initialize for delay interval 
Initialize for pulse output 
Pulse IRQ service 
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7. Procedure name: ser input 

The conclusion of the algorithm for BREAK 
detection requires the Serial Receive Shift 
register to be cleared of the character 
currently being collected (if any). This 
requires a software wait loop of a 
one-character duration. The following 
explains the algorithm used (code lines 464 
through 472, Part II): 



1 character time 



( 128xPRE0xT0 ) sec bit 
XTAL . bit ^ char 



1280xPRE0xT0 sec 
char 



XTAL 

A software loop equal to one character time is 
needed: 



1 character time = ■ 



XTAL cycle 

2n sec 
XTAL 1^ 



cycle 
loop 



Solve for n: 

( 1280 X PREO X TO ) _ 2n 
XTAL " XTAL 

n = 640 X PREO x TO 



8. 



The register pair SERhtime, SERItime was 
initialized during ser init to equal the 
product of the prescaler and the counter 
selected for the baud rate clock. That is, 

SERhtime, SERItime = PREO x TO 

The instruction sequence 

inlop: Id rSERtmpl, #53 (6 cycles) 

Ipl: djnz rSERtmpl, Ipl (12/10 cycles 

taken/not taken) 

executes in 

6 + (52 X 12) + 10 cycles = 640 cycles 



BREAK detection on the serial input line 
requires that the receive interrupt service 
routine be entered within a half-a-bit time, 
since the routine reads the input line to 
detect a true ( = 1) or false (=0) stop bit. 
Since the interrupt request is generated 
halfway through reception of the stop bit, 
half-a-bit time remains in which to read the 
stop bit level. Interrupt priorities and 
interrupt nesting should be established 
appropriately to ensure this requirement. 



1/2 bit time r 



( 128 X PREO X TO ) 
XTAL X 2 



Table 3. Decinal ASCII Character String Interpretation 



Result - 



Input String 



Sign Pre-Oecinal Post-Decimal 
Digits Digits 



Teminator 



+1234.567, 

+ +.789+ 

1234.. 
4976- 



1254 



1234 



567 
789 



4976 



NOTE: The terminator can be any ASCII character that is not a valid ASCII string 
character. 
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ROMLESS Z8 SUBROUTINE LIBRARY PART I 



Z8ASM 3.02 

LOG OBJ CODE STMT SOURCE STATEMENT 



1 
2 
3 PART I MODULE 

5 

6 !• ROMLESS Z8' SUBROUTINE LIBRARY PART I 

7 

8 Initialize: a) Port & Port 1 set up to address 

9 6MK external memory; 

10 b) internal stack belaw allocated 

11 RAM for subroutines; 

12 c) normal memory timing; 

13 d) IMR, IRQ, TMR, RP cleared; 

1M e) Port 2 inputs open-drain pull-ups; 

15 f) Data Memory select enabled; 

16 g) EI executed to 'unfreeze* IRQ; 

17 h) Jump to %0812. 
18 

19 

20 Note: The user is free to modify the initial 

21 conditions selected for a, b, and c above, 

22 via direct modification of the Port & 1 

23 Mode register (P01M, %F8). 
24 

25 The user is free to modify the conditions 

26 selected in the Port 3 Mode register (P3M, %F7). 

27 However, please note that P3M is a write-only 

28 register. This subroutine library maintains 

29 . an image of P3M in its register P3M_save i%lF) . 

30 If software outside of the subroutine package 

31 is to modify P3M, it should reference and modify 

32 P3M_save, prior to modification of P3M. For 

33 example, to select P32/P35 for handshake, use 

34 an instruction sequence such as: 
35 

36 OR P3M save,//%04 

37 LD P3M,P3M save 
38 

39 This is important if the serial and/or timer/ 

40 counter subroutines are to be used, since these 

41 routines may modify P3M. 

42 ! 
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kU ! Access to GLOBAL subroutines in this library should 

45 be made via a CALL to the corresponding entry in the 

46 jump table which begins at address ^OOOF, The jump 

47 table should be referenced rather than a CALL to the 

48 actual entry point of the subroutine to avoid future 

49 conflict in the event such entry points change in 

50 potential future revisions. 
51 

52 Each GLOBAL subroutine in this listing is headed by a 

53 comment block specifying its PURPOSE and calling 

54 sequence (INPUT and OUTPUT parameters). For many of 

55 the subroutines in this library, the location of the 

56 operands (sources/destinations) is quite flexible 

57 between register memory, external memory (code/data), 

58 and the serial channel (if enabled). The description 

59 of each parameter specifies what the location choices 

60 are: 
61 

62 - The location designation 'in reg/ext memory'- 

63 implies that the subroutine allows that the operand 

64 exist in either register or external data memory 

65 The address of such an operand is contained 

66 in the designated register pair. If the high byte of 

67 that pair is zero, the operand is in register memory 

68 at the address given by the low byte of the register 

69 pair. Otherwise, the operand is in external data 

70 memory (accessed via LDE). 
71 

72 - The location designation 

73 'in reg/ext/ser memory' implies the same 

74 considerations as above with one enhancement: if both 

75 bytes of the reg. pair are zero, the operand exists 

76 in the serial channel. In this case, the register 

77 pair is not modified (updated). For example, rather 

78 than storing a destination ASCII string in memory, it 

79 might be desirable to output such to the serial line. 

80 ! 
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82 CONSTANT 

83 ! Register Usage! 
84 

85 RAM START := ^7F 

86 "" 

87 P3M save := RAM_START 

88 TEMT 3 := P3M save-1 

89 TEMP""2 :z TEM"F 3-1 

90 TEMP"*1 := TEMP~2-1 

91 TEMP~i| := TEMP~1-1 
92 

93 !The following registers are modified/referenced 

94 by the Serial Routines ONLY. They are 

95 available as general registers to the user 
who does not intend to make use of the 
Serial Routines! 



96 
97 
98 

99 SER_char 

100 SER tmp2 

101 SER~tmp1 

102 SER put 

103 SER_len 

104 SER buf 

105 SER_imr 

106 SER__cfg 



TEMP_4-1 
SER__char-1 
SER tmp2^1 
SER^mpl-l 
SER put-1 
SER~len-2' 
SER buf-1 
SER~imr-1 



107 ! Serial Configuration Data 



=1 => odd parity on 
: =1 s> even parity on 
6,7 = 11 => undefined) 

undefined 

undefined 



108 bit 7 

109 bit 6 

110 (bit 

111 bit 5 

112 bit 4 

113 bit 3 : =1 => 

114 bit 2 : =1 ?> 

115 bit 1 : =1 => 

116 bit ,: =1 => 

117 ! 

118 op 

119 ep 

120 ie 

121 al 

122 be 

123 ec 

124 SER get 

125 SER~flg 

126 ! Serial Status Flags 



input editting on 
auto line feed enabled 
BREAK detection enabled 
input echo on 

%80 

%no 

%04 

?&02 

%0^ 

:= SER cfg-1 

:r SER get-1 



127 bit 

128 bit 

129 bit 

130 bit 

131 bit 

132 bit 

133 bit 1 

134 bit 

135 ! 

136 sd 

137 pe 

138 bd 

139 bp 

140 bne 

141 bf 
142 

143 RAM TMR 

144 

145 SERltime 



1 => serial I/O disabled 
undefined 
undefined 

=1 => parity error 
=1 => BREAK detected 
=1 => input buffer overflow 
=1 => input buffer not empty 
=1 => input buffer full 



%^o 








%08 








%0i\ 








^02 








%o^ 








: = 


RAM__ 


STAF 


U 


: = 


SER 


.flg-1 
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146 SERhtime := SERltime-1 
147 

148 !The following registers are modified/referenced 

149 by the Timer/Counter Routines ONLY. They are 

150 available as general registers to the user 

151 who does not intend to make use of the 

152 Timer/Counter Routines! 
153 

154 TOD tic := RAM TMR-2 

155 TOD~imr := T0D~tic-1 

156 TOD hr ;r TOD imr-1 

157 TOD_min := T0D;3hr-1 

158 TOD_sec ;r T0D__inin-1 

159 TOD tt := TOD sec-1 

160 PLS~1 := TOD tt-1 

161 PLS^tmr :r PLS^I-I 

162 PLS 2* := PLS^tmr-1 

163 "■ 

164 RAM__END := PLS 2 • 

165 STACK := RAM^END 
166 

167 ! Equivalent working register equates 

168 for above register layout! 
169 

170 !register file ^70 - %7F! 



171 RAM STARTr 
172 

173 rP3Msave 

174 rTEMP_3 

175 rTEMP 2 

176 rTEMP~1 

177 rrTEMP_1 

178 rTEMP 1h 

179 rTEMP"^11 

180 rTEMP~4 

181 rSERcFar 

182 rSERtmp2 

183 rSERtmpI 

184 rrSERtmp 

185 rSERtmpl 

186 rSERtmph 

187 rSERput 

188 rSERlen 

189 rrSERbuf 

190 rSERbufh 

191 rSERbufl 

192 rSERimr 

193 rSERcfg 

194 rSERget 

195 rSERflg 
196 
197 

198 !register file %60 

199 RAM TMRr 

200 rTOUtic 

201 rTODimr 

202 rTODhr 

203 rTODmin 

204 rTODsec 

205 rTODtt 

206 rPLS 1 

207 rPLS^mr 

208 rPLS 2 



%70 

R15 

R14 

R13 

R12 

RR12 

R12 

R13 

R11 

RIO 

R9 

R8 

RR8 

R9 

R8 

R7 

R6 

RR4 

B4 

R5 

R3 

R2 

R1 

RO 



%6F! 
%60 
R13 
R12 
R11 
RIO 
R9 
R8 
R7 
R6 
R5 



!for SRP! 



!for SRP! 
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210 


EXTERNAL 












211 


ser init 


PROCEDURE 










212 


ser_input 


PROCEDURE 










213 


ser rlin 


PROCEDURE 










214 


ser rabs 


PROCEDURE 










215 


ser break 


PROCEDURE 










216 


ser flush 


PROCEDURE 










217 


ser wlin 


PROCEDURE. 










218 


ser^wabs 


PROCEDURE 










219 


ser~wbyt 


PROCEDURE 










220 


ser disable 


PROCEDURE 










221 


ser get 


PROCEDURE 










222 


ser'"output 


PROCEDURE 










223 


tod""! 


PROCEDURE 










224 


tod"" 


PROCEDURE 










225 


delay 


PROCEDURE 










226 


pulse i 


PROCEDURE 










227 


pulse 


PROCEDURE 










228 














229 












i" 


230 


$SECTION PROGRAM 










231 


GLOBAL 












232 














233 














234 


! Interrupt vec 


tors! 




p 


0000 


0800 


235 


IRQ ARRAY 


[1 word] 


[%0800] 


p 


0002 


0803 


236 


IRQ^I ARRAY 


[1 word] 


[$0803] 


p 


0004 


0806 


237 


IRQ 2 ARRAY 


[1 word] 


[%0806] 


p 


0006 


0809 


238 


IRQ 3 ARRAY 


[1 word] 


C%0809] 


p 


0008 


080C 


239 


IRQ 4 ARRAY 


[1 word] 


[%080C] 


p 


OOOA 


080F 


240 
241 
242 


IRQ 5 ARRAY 


[1 word] 


C%080F] 



236 



P oooc 

P oooc 8D 007B» 
P OOOF 



P OOOF 28 43 29 
P 0012 31 39 38 



2U4 GLOBAL 
245 

246 !Jump Table! 

247 ENTER PROCEDURE 

248 ENTRY 

249 JP INIT 

250 END ENTER 
251 

252 

253 copyright ARRAY [» BYTE] 



:= •(C)1980ZILOG' 



P 0015 


30 


5A 49 








P 0018 


4C 


4F 47 


254 












255 


! Subroutine 


Entry Points! 


P 001B 






256 


JUMP PROCEDURE 








257 


ENTRY 










258 












259 


IBinary Arithmetic Routines! 








260 






P 001B 


8D 


0099' 


261 
262 


JP 


divide 


P 001E 


8D 


00B7* 


263 
264 


JP 


div_16 


P 0021 


8D 


00E2' 


265 
266 
267 


JP 


multiply 


P 0024 


8D 


00F6' 


JP 


mult 16 








268 




"~ 








269 












270 


!BCD Arithmetic Routines! 








271 






P 0027 


8D 


011A» 


272 
273 


JP 


bcdadd 


P 002A 


8D 


0117' 


274 
275 


JP 


bcdsub 








276 


! Conversion 


Routines! 








277 






P 002D 


8D 


0205' 


278 
279 


JP 


bcddasc 


P 0030 


8D 


0363' 


280 
281 


JP 


dascbcd 


P 0033 


8D 


0284' 


282 
283 


JP 


bcdwrd 


P 0036 


8D 


02CD' 


284 
285 


JP 


wrdbcd 


P 0039 


8D 


025C' 


286 
287 


JP 


bythasc 


P 003C 


8D 


0257' 


288 
289 


JP 


wrdhasc 


P 003F 


8D 


0319' 


290 
291 


JP 


hascwrd 


P 0042 


8D 


03BE' 


292 
293 


JP 


wrddasc 


P 0045 


8D 


034D» 


294 
295 


JP 


dascwrd 








296 


!Bit Manipulation Routines! 








297 






P 0048 


8D 


04Ar 


298 
299 


JP 


clb 


P 004B 


80 


04B9' 


300 
301 


JP 


tjm 








302 


!Serial Routines! 








303 






P 004E 


8D 


0000» 


304 


JP 


ser init 



!16/8 unsigned binary 

division! 
! 16/16 unsigned binary 

division! 
!8x8 unsigned binary 

multiplication! 
! 16x16 unsigned binary 

multiplication! 



!BCD addition! 
!BCD subtraction! 

!BCD to decimal ASCII! 
! Decimal ASCII to BCD! 
!BCD to binary word! 
! binary word to BCD! 
!Bin. byte to Hex ASCII! 
!Bin. word to hex ASCII! 
!Hex ASCII to bin word! 
!Bin. word to dec ASCII! 
!dec ASCII to bin word! 

!collect bits in a byte! 
! Table Jump Under Mask! 

! initialize serial I/O! 
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305 










P 0051 8D 


0000* 


306 
307 




JP 


ser input 


»IRQ3 (receive) service! 


P 0054 8D 


0000» 


308 
309 




JP 


ser_rlin 


!read line! 


P 0057 8D 


0000* 


310 
311 




JP 


ser_rabs 


!read absolute! 


P 005A 8D 


0000* 


312 
313 




JP 


ser_break 


1 transmit BREAK! 


P 005D 8D 


0000* 


314 
315 




JP 


ser_flush 


! flush (clear) 
input buffer! 


P 0060 8D 


0000* 


316 
317 




JP 


ser_wlin 


!write line! 


P 0063 8D 


0000* 


318 
319 




JP 


ser__wabs 


iwrite absolute! 


P 0066 8D 


0000* 


320 
321 




JP 


ser wbyt 


'write byte! 


P 0069 8D 


0000* 


322 
323 




JP 


ser_disable 


!disable serial. I/O! 






324 


! Timer/Counter 


Routines! 








325 










P 006C 8D 


0000* 


326 
327 




JP 


tod_i 


!init for time of day! 


P 006F 8D 


0000* 


328 
329 




JP 


tod 


!tod IRQ service! 


P 0072 8D 


0000* 


330 
331 




JP 


delay 


!init for delay interval 


P 0075 8D 


0000* 


332 
333 




JP 


pulse_i 


!init for pulse output! 


P 0078 8D 


0000* 


334 
335 




JP 


pulse 


! pulse IRQ service! 


P 007B 




336 


END 


JUMP 










338 


Ilnitialization 


! 




? 00 7B 




339 


INIT 


PROCEDURE 








340 


ENTRY 












341 










P 007B E6 


F8 D7 


342 




LD 


P01M,#%(2)11010111 






343 








! internal stack; 






344 








AD0-A15; 






345 








normal memory 






346 








timing ! 


P 007E E6 


7F 10 


347 




LD 


P3M_save,#%(2)00010000 






348 








!P3M is write-only, 






349 








so keep a copy in 






350 








RAM for later 






351^ 








reference ! 


P 0081 EU 


7F F7 


352 




LD 


P3M,P3M save 


!set up Port 3 ! 


P 0084 E6 


FF 65 


353 




LD 


SPL,#ST1CK 


! stack pointer ! 


P 0087 BO 


F1 


354 




CLR 


TMR 


!reset timers! 


P 0089 E6 


F6 FF 


355 




LD 


P2M,//%FF 


!all inputs! 


P 008C BO 


FA 


356 




CLR 


IRQ 


! reset int. requests! 


P 008E BO 


FB 


357 




CLR 


IMR 


!disable interrupts ! 


P 0090 BO 


FD 


358 




CLR 


RP 


iregister pointer! 


P 0092 E6 


70 80 


359 




LD 


SER_flg,#%80 


!serial disabled! 


P 0095 9F 




360 
361 




EI 




!globally enable 
interrupts ! 


P 0096 8D 


0812 


362 
363 




JP 


^0812 




P 0099 




364 


END 


INIT 
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Binary Arithmetic Routines 



P 0099 



p 


0099 


A9 


7C 


p 


009B 


AC 


08 


p 


009D 


A2 


BC 


p 


009F 


SB 


02 


p 


00A1 


DF 




p 


00A2 


AF 




p 


00A3 


10 


ED 


p 


00A5 


10 


EC 


p 


00A7 


7B 


on 


p 


00A9 


A2 


BC 


p 


DOAB 


BB 


03 


p 


OOAD 


22 


CB 


p 


OOAF 


DF 




p 


OOBO 


AA 


F1 



P 00B2 10 ED 



P OOBM A8 
P 00B6 AF 
P 00B7 



7C 



397 CONSTANT 

398 div LEN 

399 DIVTSOR 

400 dividend HI 

401 dividend LO 

402 GLOBAL 

403 divide PROCEDURE 



RIO 
R11 
R12 
Rt3 



404 
405 
406 
407 
408 
409 
410 
411 
412 
413 
414 
415 
416 



I »««»»«»»»««»»»««»»»»»»»»» »»ft«»»»i«ii»»»ft »««««»»»»»»»«» 



Purpose 



Input = 



Output 



To perform a 16-bit by 8-bit unsigned 
binary division. 

R11 = 8-bit divisor 
RR12 = 16-bit dividend 



R13 = 8-bit quotient 
R12 = 8-bit remainder 
Carry flag = 1 if overflow 

= if no overflow 
R11 unmodified 

417 ENTRY 

418 Id TEMP 1,div LEN 1 save caller's RIO! 
Id div LEN, #8 fLOOP COUNTER! 



! CHECK IF RESULT WILL FIT IN 8 BITS! 



419 
420 
421 
422 
423 
424 

425 

426 

427 

428 LOOP: 

429 

430 

431 

432 

433 subt: 

434 

435 next: 

436 

437 !ALL 

438 

439 

440 

441 



cp 
jr 
! over flow! 
SCF 
ret 



RLC 

RLC 

jr 

cp 

Jr 

SUB 

SCF 

djnz 

DONE! 
RLC 

Id 
ret 



DIVISOR, dividend HI 
UGT,LOOP TCARRY 



= (FOR RLC)! 



! CARRY = 1! 



dividend LO ! DIVIDEND » 2! 

dividend^HI 

c,subt 

DIVISOR, dividend_HI 

UGT,next !CARRY = 0! 

dividend HI, DIVISOR 

!T0 BE SHIFTED INTO RESULT! 



div LEN, LOOP 



dividend_LO 
div LEN,TEMP__1 



!no flags affected! 



! CARRY = 0: no overflow! 
!restore caller's RIO! 



442 END divide 
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P 00B7 





00B7 


79 


7C 




00B9 


7C 


10 




OOBB 


CF 






ODBC 


BO 


EA 




OOBE 


BO 


EB 




OOCO 


10 


ED 




00C2 


10 


EC 




00C4 


10 


EB 




00C6 


10 


EA 




00C8 


7B 


OA 




OOCA 


A2 


8A 




OOCC 


BB 


OB 




OOCE 


7B 


04 




OODO 


A2 


9B 




00D2 


BB 


05 




00D4 


22 


B9 




00D6 


32 


AS 




00D8 


DF 






00D9 


7A 


E5 




OODB 


10 


ED 




OODD 


10 


EC 




OODF 


78 


7C 




00E1 


AF 






00E2 







P 00E2 



p 


00E2 


A9 


7C 


p 


00E4 


AC 


09 


p 


00E6 


BO 


EC 


p 


00E8 


CF 




p 


00E9 


CO 


EC 


p 


OOEB 


CO 


ED 


p 


OOED 


FB 


02 


p 


OOEF 


02 


CB 


p 


00F1 


AA 


F6 


p 


00F3 


A8 


7C 


p 


00F5 


AF 




p 


00F6 







444 CONSTANT 

445 d16_LEN 
dvsr_hi 
dvsr_lo 
rem^hi 
rem lo 
quo'E__hi 
quot lo 

452 GLOBAX 

453 div 16 



446 
447 
448 
449 
450 
451 



R7 

R8 

R9 

RIO 

R11 

R12 

R13 



PROCEDURE 



454 
455 
456 
457 
458 
459 
460 
461 
462 
463 
464 



I ft«7»»« »«»»»»»« t «»»«««»»«««»«««»««»»»»««»«« «»»«»»«»««« 



Purpose 



Input = 



To perform a 16-bit by 16-bit unsigned 
binary division. 



RR8 = 
RR12 



16-bit divisor 
: 16-bit dividend 



Output = RR12 = 16-bit quotient 
RR10 = 16-bit remainder 
RR8 unmodified 
««»»«»«»»««»«»»»«««»»«««««»»««»»»»«»»«»«»««*«)(«»»«»«« f 

465 ENTRY 

466 Id TEMP 1,dl6 LEN 
dl6 rEN,#lF 



Id 

467 Id 

468 rcf 

469 clr 

470 clr 

471 dlp_16: rlc 

472 rlc 

473 rlc 

474 rlc. 

475 ^ jr 

476 cp 

477 jr 

478 jr 

479 cp 

480 jr 

481 subt 16: sub 



482 
483 



sbc 
scf 



484 skp_16: djnz 



485 
486 
487 
488 



rlc 
rlc 
Id 
ret 



489 END div_l6 

491 CONSTANT 

492 MULTIPLIER 

493 PRODUCT_LO 

494 PRODUCT_HI 

495 mul LEN 

496 GLOBXL 

497 multiply 



rem_hi 

rem lo 

quof__lo 

quot hi 

r em__To 

rem_hi 

c ,subt_l6 

dvsr_hi,rem_hi 

ugt ,skp_16 

ult ,subt_16 

dvsr_lo,rem_lo 

ugt,skp 16 

rem_lo,"a"vsr_lo 

rem_hi,dvsr_hi 

d16 LEN,dlp_16 

quof__lo 

quot hi 

d16 rEN,TEMP_1 



R11 
R13 
R12 
RIO 



!save caller's RIO! 
!LOOP COUNTER! 
•carry = 0! 



!no flags affected! 



498 
499 
500 
501 
502 
503 
504 
505 
506 
507 



Purpose = 



PROCEDURE 

To perform an 8-bit by 8-bit unsigned 
binary multiplication. 



Input = R11 = multiplier 

R13 = multiplicand' 

Output = RR12 = product 
R11 unmodified 



508 ENTRY 

509 

510 

511 

512 

513 L00P1 

514 

515 

516 

517 NEXT: 



518 
519 
520 END 



Id 

Id 

clr 

RCF 

RRC 

RRC 

jr 

ADD 

djnz 

Id 

ret 

mult 



TEMP 1,mul LEN !save caller's RIO! 

mul_i:EN,//9" !8 BITS! 

PRODUCT HI !INIT HIGH RESULT BYTE! 

!CARRY = 0! 
PRODUCT HI 
PRODUCT__LO 
NC,NEXT 

PRODUCT__HI , MULTIPLIER 
mul_LEN,L00P1 
mul LEN, TEMP 1 !restore caller's RIO! 



iply 



240 



P 00F6 



p 


00F6 


79 


7C 


p 


00F8 


7C 


11 


p 


OOFA 


BO 


EA 


p 


OOFC 


BO 


EB 


p 


OOFE 


CF 




p 


OOFF 


CO 


EA 


p 


0101 


CO 


EB 


p 


0103 


CO 


EC 


p 


0105 


CO 


ED 


p 


0107 


FB 


O.M 


p 


0109 


02 


B9 


p 


010B 


12 


A8 


p 


010D 


7A 


FO 


p 


010F 


78 


7C 


p 


0111 


A9 


7C 


p 


0113 


HH 


EB 


p 


0116 


AF 




p 


0117 







7C 



522 CONSTANT 

523 ml6_LEN 
52M plier__hi 

525 plier lo 

526 prodjii 

527 prod_lo 

528 mult_hi 

529 mult lo 

530 GLOBAt 

531 mult 16 PROCEDURE 



R7 

R8 

R9 

RIO 

R11 

R12 

R13 



532 
533 
53^ 
535 
536 
537 
538 
539 
5^0 
541 
5M2 
5M3 
5MM 



I »«»T )!«»»« »»»»»«»« ««»»«»«««»» «»««tt»«llllftll «»»«»«»«««»«» 



Purpose = 



Input = 



Output r 



To perform an 16-bit by 16-bit unsigned 
binary multiplication. 

RR8 = multiplier 
RR12 = multiplicand 



RQ10 = product (RIO, R11, R12, R13) 
RR8 unmodified 

Zero FLAG = if result > 16 bits 
= 1 if result fits in 16 
(unsigned) bits (RR12 = result) 

5M5 ENTRY 

5M6 Id TEMP 1,m16 LEN 

ml6_rEN,//lT 

prod__hi 

prod lo 



547 
548 
549 
550 



Id 

Id 

clr 

clr 

rcf 



!save caller's R7! 
!16 BITS! 



! init product! 
!CARRY = 0! 



551 loop16: rrc 



552 

553 

554 

555 

556 

557 

558 next16: 

559 

560 

561 

562 

563 END 



rrc 

rrc 

rrc 

jr 

add 

adc 

djnz 

Id 

Id 

or 

ret 

mult 16 



prod__hi 

prod_lo 

mult_hi 

mult_lo 

nc ,next16 

prod_lo , plier lo 

prod_hi jplierH^i 

m16 LEN,loopl6 !next bit! 

m16~LEN,TEMP_1 

TEMP_1,prod_hi 

TEMP 1,prod lo 



!bit to carry! 
!multiplicand / 2! 



!restore caller's R7! 
! test product. . . ! 
! ...bits 31 - 16! 
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BCD Arithmetic Routines 



593 I The BCD format supported by the following arithmetic 

594 and conversion routines allows representation 

595 of signed magnitude variable precision BCD 

596 numbers. A BCD number of 2n digits is 

597 represented in n+1 consecutive bytes where 

598 the byte at the lowest memory address 

599 (*byte 0') represents the sign and post- 
600 decimal digit count, and the bytes in the 

601 next n higher memory locations (♦byte 1' 

602 through ♦byte n») represent the magnitude 

603 of the BCD number. The address of 'byte 0' 

604 and the value n are passed to the subroutines 

605 in specified working registers. Digits are 

606 packed two per byte with the most 

607 significant digit in the high order nibble 

608 of 'byte 1' and the least significant digit 

609 in the low order nibble of 'byte n'. 'Byte 0' 

610 is organized as two fields: 

611 bit 7 represents sign: 

612 = 1 => negative 

613 .= => positive 

614 bit 6-0 represent post-decimal digit 

615 count 

616 For example: 

617 'byte 0'= %05 

618 = %80 

619 = %90 

620 I 



=> positive, with 5 post-decimal digits 
5> negative, with no post-decimal digits 
r> negative, with 16 post-decimal digits 



P 0117 



P 0117 B7 EE 80 
P 011A 



622 
623 
624 
625 
626 
627 
628 
629 
630 
631 
632 
633 
634 
635 
636 
637 
638 
639 
640 
641 
642 
643 
644 
645 
646 
647 
648 
649 
650 
651 



CONSTANT 

bed LEN := R12 

bcd];;SRC :r R14 

bed DST := R,15 
GLOBlL 
bcdsub PROCEDURE 

Purpose = To subtract two packed BCD strings of 
equal length, 
dst < — dst - src 



Input = 



Output 



R15 = address of destination BCD 
string (in register memory). 

R14 = address of source BCD 

string (in register memory). 

R12 = BCD digit count / 2 



Destination BCD string contains the 
difference. 
Source BCD string may be modified. 
R12, R14, R15 unmodified if no error 
R13 modified. 

Carry FLAG = 1 if underflow or format 
error . 

ENTRY 

xor §bcd_SRC,#%80 .'complement sign of 

subtrahend! 
!fall into bcdaddl 
END bcdsub 
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653 GLOBAL 

P 01 1A 654 bcdadd PROCEDURE 

655 !**»»»»»*»»»*»»»<»»»**«»««»*»***««)(«*)* M «**»»**»«»*»»*» 

656 Purpose = To add two packed BCD strings of 

657 equal length. 

658 dst < — dst + src 

659 ^ 

660 Input = R15 = address of destination BCD 

661 string (in register memory). 

662 R14 = address of source BCD 

663 string (in register memory). 
66M R12 = BCD digit count / 2 

665 

666 Output s Destination BCD string contains the sum. 

667 Source BCD string may be modified. 

668 R12, R14, R15 unmodified if no error 

669 R13 modified. 

670 Carry FLAG = 1 if overflow or format 

671 error. 

572 »»»»»«»»»»»«« »]!«»»»»»»»« »»«»»« »»»»»»»»»«»»»»«»»«»«»»»! 

673 ENTRY 

67^ Idelete all leading pre-decimal zeroes! 

P 011A E6 7E 02 675 Id TEMP_3,#2 

P 011D D8 EE 676 Id R13,bcd SRC 

P 01 IF C9 7B 677 b^a 3: Id TEMP_i|,Fcd_LEN 

P 0121 OU 7B 7B 678 " add TEMP__4,TEMP_4 !total digit count! 

P 0124 E5 ED 7D 679 Id TEMP 2,§R13 !get. sign/post dec // ! 

P 0f27 56 7D 7F 680 and TEMP 2,#%7F ! isolate post dec //! 

P 0i2A 24 7D 7B 681 sub TEMP 4,TEMP_2 !pre-dec digit cnt! 

P 012D 7D 0203' 682 jp ult,¥a_err ! format error! 

P 0130 6B 1A 683 jr z,ba 1 !no pre-dec. digits! 

P 0132 70 EC 684 ba_2: push R12 isave! 

P 0134 C7 CD 01 685 Id. R12,1(R13) !leading byte! 

P 0137 76 EC FO 686 tm R12,//%F0 !test leading digit! 

P 013A 50 EC 687 pop R12 !restore! 

P 013c EB OE 688 jr nz,ba 1 !no more leading O's! 

P 01 3E BO 7C 689 clr TEMP_T 

P 0140 D6 0463' 690 call rdl !rotate left! 

P 0143 21 ED 691 inc §R13 !update post dec #! 

P 0145 4D 0203' 692 jp ov,ba err !oops! 

P 0148 00 7B 693 dec TEMP__Tr !dec pre-dec //! 

P 014A EB E6 694 jr nz,ba_2 !loop! 

P 014C D8 EF 695 ba 1 : Id R13,bcd__DST 

P 01 4E 00 7E 696 "" dec TEMP_3 !SRC and DST done?! 

P 0150 EB CD 697 jr nz,ba__3 !do DST! 

698 ! leading zero deletion complete! 

699 ! insure DST is > or = SRC; exchange if necessary! 
P 0152 E3 DF 700 Id R13,@bcd_DST 

P 0154 56 ED 7F 701 and R13,#%7F !isolate post dec //! 

P 0157 E5 EE 7D , 702 Id TEMP_2,@bcd_SRC 

P 015A 56 7D 7F 703 and TEMP_2,#$7F ! isolate post dec #! 

P 015D A4 7D ED 704 cp R13,TEMP_2 

P 0160 70 ED 705 push RI3 !save! 

P 0162 7B 39 706 jr ult,ba__4 !DST > SRC! 

P 016i| BB 18 707 jr ugt,ba_5 !DST < SRC! 

708 !decimal points in same position. 

709 must compare magnitude! 

P 0166 D8 EC 710 Id R13,bcd LEN 

P 0168 E9 7C 711 Id TEMP_1 ,Fcd_SRC 

P 01 6A F9 7B 712 Id TEMP_4,bcd_DST 

P 016C 20 7C 713 ba 6: inc TEMP 1 

P 016E 20 7B 714 ~ inc TEMP_4 

P 017a E5 7C 7E 715 Id TEMP_3,@TEMP_1 !get SRC byte! 

P 0173 A5 7B 7E 716 cp TEMP_3,§TEMP_4 !compare DST byte! 
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P 0176 BB 06 717 jr ugt,ba_5 !SRC > DST! 

P 0178 7B 23 718 jr ult,ba_M !SRC < DST! 

P 017A DA FO 719 djnz R13»ba__6 Hoop! 

P 017C 8B IF 720 jr ba_4 !DST > or r SRC! 

721 !swap source and destination operands! 

P 017E D8 EC 722 ba 5: Id R13,bcd LEN 

P 0180 DE 723 "" inc R13 ~ !include flag/size byte! 

P 0181 02 ED 72M add bcd__SRC,R13 

P 0183 02 FD 725 add bcd_DST,Rl3 

P 0185 00 EE 726 ba 7: dec bed SRC 

P 0187 00 EF 727 "" dec bcd~DST 

P 0189 E5 EE 7C 728 Id TEMP 1,§bcd SRC 

P 01 8C E5 EF 7B 729 Id TEMP3,@bcd~DST 

P 01 8F F5 7B EE 730 Id §bcd_SRC,TEMP_U 

P 0192 F5 7C EF 731 Id @bcd DST, TEMP 1 !one byte swapped! 

P 0195 DA EE 732 djnz R13,^a 7 " ^ ^ 

P 0197 D8 7D 733 Id R13,TEHp__2 

P 0199 50 7D 73M pop TEMP 2 

P 019B 70 ED 735 push R13 

736 !exchange complete! 

P 019D 50 ED 737 ba 4: pop R13 !restore! 

738 !RT3 = DST post decimal digit count 

739 TEMP 2 = SRC post decimal digit count 
7M0 R13 =< TEMP 2 ! 

P 019F 2n ED 7D 7^1 sub TEMP_2,R13 

P 01A2 CO 7D 7M2 rrc TEMP_2 !alignment offset! 

P OIAM FB 09 . 7^3 jr nc,ba_8 !digits word aligned! 

7UU !rotate out least significant SRC post decimal digit! 

P 01A6 D8 EE 7^5 Id R13,bcd_SRC 

P 01A8 01 ED 7^6 dec §R13 !dec post dec digit #! 

P 01AA BO 7C 747 clr TEMP_1 

P 01AC D6 0U85' 748 call rdr 

749 !determine if addition or subtraction! 

P 01 AF E5 EE 7B 750 ba 8: Id TEMP 4,§bcd SRC !sign of SRC! 

P 01B2 B5 EF 7B 751 " xor TEMP"4,§bcd^DST !sign of DST! 

752 !get starting addres'fes! 

P 01B5 D8 EC 753 Id R13,bcd LEN 

P 01B7 24 7D ED 754 sub R13,TEMT_2 

P 01BA 6B 45 755 jr z,ba_14 !done already! 

P 01BC 02 ED 756 add bed SRC,R13 

P 01BE 02 FC 757 add bcd_DST,bcd_LEN 

758 !ready!!! 

P 01C0 CF 759 rcf !carry = 0! 

P 01C1 E5 EF 7C 760 ba 11: Id TEMP_1 ,@bcd_DST 

P 01C4 76 7B 80 761 tm TEMP__4,#%80 !add or sub?! 

P 01C7 6B 05 762 jr z,ba 9 !add!. 

P 01C9 35 EE 7C 763 sbc TEMP""l ,@bcd_SRC 

P 01CC 8B 03 764 jr ba ITJ 

P 01CE 15 EE 7C 765 ba__9: adc TET1P_1 ,@bcd_SRC 

P 01D1 40 7C 766 ba 10: da TEMP_1 

P 01D3 F5 7C EF 767 "" Id @bcd DST,TEMP_1 

P 01D6 00 EF 768 dec bcd^TJST 

P 01D8 00 EE 769 dec bed SRC 

P 01DA DA E5 770 djnz R13Tba 11 

771 ! propagate carry thru TEMP_2 bytes of DST! 

P 01DC D8 7D 772 Id R13,TEMP_2 

P 01DE DE 773 inc R13 !may be zero! 

P 01DF DA 02 774 djnz R13,ba_12 

P 01E1 8B 09 775 jr ba__13 

P 01E3 17 EF 00 776 ba 12: adc @bed DST,y/0 

P 01E6 41 EF 777 " da §bcd"'DST 

P 01E8 00 EF 778 dec bcd_1JST 

P 01EA DA F7 779 djnz R13,ba_12 
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780 Icarry propagate complete! 
P 01EC FB 13 781 ba__13: jr nc,ba_1i| fdone! 

782 ! Rotate out least significant post decimal DST 

783 digit to make room for carry at high end! 
P 01EE E5 EF 7C 784 Id TEMP_1 ,§bcd_DST 

P 01F1 56 7C 7F 785 and TEMP_1,y/%7F 

P OlFil 6D 0203* 786 jp z,ba err !no post dec digits! 

P d1F7 E6 7C 10 787 Id TEMP"1,//%10 

P 01FA D8 EF 788 Id , R13,^cd_DST 

P 01FC D6 0485* 789 call rdr 

P 01FF 01 EF 790 dec §bcd DST !dec digit cnt! 

P 0201 CF 791 ba 14: rcf 

P 0202 AF 792 ret 

793 
P 0203 DF 794 ba err: scf 

P 0204 AF 795 ret 

P 0205 796 END bcdadd 
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Conversion Routines 



P 0205 



0205 E6 
0208 77 
020B EB 
020D E6 
0210 E5 
0213 56 
0216 02 
0218 70 
021A 2M 
021D 50 
021F 7B 
0221 D6 
022U 7B 
0226 A6 

0229 6B 
022B 76 
022E EB 

0230 DE 

0231 E5 
023U FO 
0236 EM 
0239 56 
023C A6 
023F BB 
02m 06 
02MM D6 
0247 00 

0249 6B 
024B CA 
024D E6 

0250 D6 
0253 8B 

0255 DF 

0256 AF 
0257 



P 0257 



P 0257 D6 
P 025A C8 

P 025c 



7C 2D 

ED 80 

03 

7C 2B 

ED 7E 

7E 7F 

CC 

EC 

7E EC 

7E 

35 

03F4' 

30 

EC 00 

22 

7E 01 

04 

ED 7D 

7D 

7D 7C 

7C OF 

7C 09 

14 

7C 30 

03F4» 

7E 

OB 

DE 

7C 2E 

03F4' 

D6 



025c • 
ED 



821 CONSTANT 

822 bca LEN 

823 bca^SRC 

824 GLOBAL 

825 bcddasc PROCEDURE 



R12 
RI3 



Input = 



Output = 



826 
827 
828 
829 
830 
831 
832 

833 

834 

835 

836 

837 

838 

839 

840 

841 

842 

843 

844 

845 

846 

847 

848 

849 bcd_d1 

850 

851 

852 

853 

854 

855 

856 ; 

857 

858 

859 

860 bed d4 

861 

862 

863 



Purpose s 



To convert a variable length BCD 
string to decimal ASCII. 

RR14 s address of destination ASCII 
string (in reg/ext/ser memory). 

RI3 = address of source BCD 

string (in register memory). 

R12 = BCD digit count / 2 



ASCII string in designated 
destination buffer. 
Carry FLAG = 1 if input format error 
or serial disabled, 
= if no error . 
R12, RI3, R14, RI5 modified. 
Input BCD string ummodified. 
»»ii»)ift»)i«»»«iiii«ii««»iii«»ii»«»»»»iiffii»«)i»»ii»«»»«»«ftft»»»ii»I 

ENTRY i 

TEMP 1,//'-' 
@bca__SRC,//%80 
nz,bcd d1 
TEMP_17/M^.» 
TEMP 3,§bca SRC 
TEMP~3,#%7r" 



Id 

tm 

jr 

Id 

Id 

and 

add 

push 

sub 

pop 

jr 

call 

jr 

cp 

jr 

tm 

jr 

inc 

Id 



Iminus sign! 

!src negative?! 

!yes! 

! positive sign! 



864 bed d3: swap 



865 

866 

867 

868 

869 

870 

871 

872 

873 

874 bed d6: 

875 

876 

877 bed d5: 

878 bed~d2: 

879 END 



Id 

and 

cp 

jr 

add 

call 

dec 

jr 

djnz 

Id 

call 

jr 

sef 

ret 

bcddasc 



__ , . ! isolate post dec ent! 
bca LEN, bca LEN ! total digit count! 
bca~LEN 

bca LEN, TEMP 3 !pre-dee digit ent! 
TEMF_3 "" ! total digit count! 
ult,bed d2 ! format error! 
put_desr !sign to dest.! 
Cjbed d2 ! serial error! 
bea__LE'N,#0 !any pre-dec digits?! 
z,bcd d6 !no. start with ».'! 
TEMP_3,/M !need next byte?! 
nzjbcd d3 !not yet.! 
bea_SR"C ! update pointer! 
TEMP 2,@bca SRC ! get next byte! 
TEMP~2 

TEMP 1,TEMP 2 
TEMP~1,//$0F"" 
TEMP 1,y^9 
ugt,5cd_d5 
TEMP 1,#%30 
put cTest 
TEM'P__3 
z,bcd_vd2 
bca LEN, bed d4 
TEMP_1,/M .' 
put dest 
bed'"d4 



! isolate digit! 

!verify bed! 

!no good! 

!convert to ASCII! 

!to destination! 

!digit count! 

!all done! 

!next digit! 

!time for dec. pt . ! 

! to destination! 

!eontinue! 

! set error return! 



881 GLOBAL 

882 wrdhasc PROCEDURE 



883 
884 
885 
886 
887 
888 
889 
890 
891 



Purpose = To convert a binary word to Hex ASCII. 

Input = RR12 = source binary word. 

RR14 = address of destination ASCII 

string (in reg/ext/ser memory). 



Note = All other details same as for bythase. 

ftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftf 

892 ENTRY 

893 call bythase !eonvert R12! 

894 Id R12,R13 

895 rfall into bythase! 

896 END wrdhasc 



246 













898 


CONSTANT 














899 


bna SRC 


:= R12 












900 


GLOBAL 






p 


025C 








901 


bythasc 


PROCEDURE 












902 


}ii»iiiiii«»««»»»»««»««ii»»iiii«««»»«»ii««ii»«»»)i»«««»ii»««»»»ii« 












903 


Purpos 


e = 


To convert a binary byte to Hex ASCII. 












904 


















905 


Input 


: 


RR14 : address of destination ASCII 












906 






string (in reg/ext/ser memory). 












907 






R12 s Source binary byte. 












908 


















909 


Output 


= 


ASCII string in designated 












910 






destination buffer. 












911 






Carry = 1 if error (serial only). 












912 






Rm, R15 modified. 












913 


»»««««»«»«««»ii»»»»ft««»»ii«»»»«ii»»«»»«»«»»«)i»«»»»«iiii»«)i| 












91M 


ENTRY 






p 


025C 


BO 


7E 




915 




clr 


MODE !flag => binary to ASCII! 


p 


025E 


E6 


7D 


02 


916 


be a go: 


Id 


TEMP 2, #2 


p 


0261 


FO 


EC 




917 


bca gol 


: SWAP 


bna ^RC ! look at next nibble! 


p 


0263 


C9 


7C 




918 




Id 


TEMF 1,bna SRC 


p 


0265 


56 


7C . 


OF 


919 




and 


TEMP 1,#^0F ! isolate low nibble! 


p 


0268 


06 


7C 


30 


920 




ADD 


TEMP~1,#%30 ! convert to ASCII! 


p 


026B 


A6 


7C 


3A 


921 




cp 


TEMP~1,#%3A !>9?! 


p 


026E 


73 


09 




922 




jr 


ult,skip !no! 


p 


0270 


DF 






923 




SCF 


!in case error! 


p 


0271 


76 


7E 


01 


92H 




TM 


M0DE,#1 !input is BCD?! 


p 


027^ 


EB 


OD 




925 




JR 


NZ,bca ex !yes. error.! 


p 


0276 


06 


7C 


07 


926 




ADD 


TEMP_l7//%07 ! input hex. adjust! 


p 


0279 


D6 


03F4» 


927 


skip: 


call 


put dest !put byte in dest! 


p 


027C 


7B 


05 




928 




Jr 


c,bca ex !ferror! 


p 


027E 


00 


7D 




929 




dec 


TEMP "5 


p 


0280 


EB 


DF 




930 




jr 


nz,bca_go1 !loop till done! 


p 


0282 


CF 






931 




RCF 


!carry = 0: no error! 


p 


0283 


AF 






932 


bca ex: 


ret 


!done! 


p 


028M 








933 


END"" 


bythasc 
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935 


CONSTANT 








^ 






936 


bccl_adr 


Is R 1 4 












937 


bed cnt 


:= R15 












938 


GLOBXL 








P 0284 








939 


bcdwrd 


PROCEDURE 












940 


i»»»»»»ii»»»»«ii»»»«ii»ii»»»»ii»»»ii«»«»»ii«tft)i»iit«»»«»««iiii»« 










941 


Purpose = 


To convert a variable length BCD 










942 






string to a signed binary word. Only 










943 






pre-decimal digits are converted. 










944 


















945 


Input 


r' 


R14 s address o: 


f source BCD 










946 






string (ii 


n register memory) . 










947 






R15 = BCD digit 


count / 2 










948 


















949 


Output 


= 


RR12 = binary word 










950 






Carry FLAG =1 


if input format error 










951 








or dest overflow, 










952 






= : 


if no error. 










953 






R14,R15 modified. 










954 


»ii»»»»»»»«ii«»iiii»»i(»»»ftii««ft«ii»»»«««»ii»ft)i«»»»iiiiif»ii)i»iiii«! 










955 


ENTRY 








P 0284 


80 


EC 




956 




elr 


R12 


!init destination! 


P 0286 


BO 


ED 




957 




elr 


R13 




P 0288 


E5 


EE 


7B 


958 




Id 


TEMP 4,@bcd adr 


!get sign/post length! 


P 028B 


56 


7B 


7F 


959 




and 


TEMP3,//%7F'" 


! isolate post length! 


P 028E 


02 


FF 




960 




add 


bed cnt, bed cnt 


l# bed digits! 


P 0290 


24 


7B 


EF 


961 




sub 


bcd""ent,TEMF 4 


!# pre-dec digits! 


P 0293 


7B 


37 




962 




jr 


ult,bcd w2 


! format error! 


P 0295 


E5 


EE 


7B 


963 




Id 


TEMP 4,?bcd adr 


!remember sign! 


P 0298 


E6 


7E 


02 


964 


bcd_w3: 


Id 


TEMP'"3,//2 


! digits per byte! 


P 029B 


EE 






965 




inc 


bed adr 


! sre address! 


P 029C 


E5 


EE 


7D 


966 




Id 


TEM7 2,§bcd adr 


!get next sre byte! 


P 029F 


A6 


EF 


00 


967 


bed w1 : 


ep 


bed cnt,#0 


!digit count = 0?! 


P 02A2 


6B 


12 




968 




jr 


z,bcd w4 


!conversion complete! 


P 02A4 


FO 


7D 




969 




swap 


TEMP ?, 


!next digit! 


P 02A6 


E4 


7D 


7C 


970 




Id 


TEMP 1,TEMP 2 




P 02A9 


D6 


042C' 


971 




call 


bcd_5in 


! accumulate in binary! 


P 02AC 


7B 


IE 




972 




jr 


e,bed w2 


! over flow or format err! 


P 02AE 


00 


EF 




973 




dec 


bed cnt 


iupdate digit count! 


P 02B0 


00 


7E 




974 




dee 


TEMT 3 


!next byte?! 


P 02B2 


EB 


EB 




975 




jr 


nz,bdd w1 


!no. same.! 


P 02B4 


8B 


E2 




976 




jr 


bed w3"" 


!next byte! 


P 02B6 


DF 






977 


bed w4: 


sef 




!in case! 


P 02B7 


76 


EC 


ao 


978 




tm 


R12,#%80 


!result > 15 bits?! 


P 02BA 


EB 


10 




979 




jr 


nz,bed w2 


ioverflow! 


P 02BC 


76 


7B 


80 


980 


bed w5: 


tm 


TEMP 4,#%80 


! source negative?! 


P 02BF 


6B 


OA 




981 




jr 


z,be3" w6 


!no. done.! 


P 02C1 


60 


EC 




982 




com 


R12 - 




P 02C3 


60 


ED 




983 




com 


R13 




P 02C5 


06 


ED 


01 


984 




add 


R13,//1 




P 02C8 


16 


EC 


00 


985 




ade 


R12,//0 


!RR12 two's complement! 


P 02CB 


CF 






986 


bed w6: 


ref 




!carry s 0! 


P 02CC 


AF 






987 


bcd~w2: 


ret 






P 02CD 








988 


END- 


bcdwrd 
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P 02CD 



02CD B1 
02CF 76 
02D2 6B 
02DU 47 
02D7 60 
02D9 60 
02DB 06 
02DE 16 
02E1 10 
02E3 10 
02E5 EE 
02E6 E9 
02E8 F9 
02EA 04 
02ED 00 
02EF 81 
02F1 EE 
02F2 FA 
02F4 E6 
02F7 70 
02F9 10 
02FB 10 
02FD E8 
02FF F8 

0301 E5 
0304 15 
0307 40 

0309 F5 
030C 00 
030E FA 

0310 50 
0312 7B 
0314 00 
0316 EB 
0318 AF 
0319 



80 



EE 

EC 80 

OD 

EE 

ED 

EC 

ED 01 

EC 00 

ED 

EC 

7C 

7D 

EF 7C 

7C 

EE 

FB 

7E OF 

7E 

ED 

EC 

7C 

7D 

EE 7E 

EE 7E 

7E 

7E EE 

EE 

F1 

7E 

04 

7E 

DF 



990 
991 
992 
993 
994 
995 
996 
997 
998 
999 
1000 
1001 
1002 
1003 
1004 
1005 
1006 
1007 
1008 
1009 
1010 
1011 
1012 
1013 
1014 
1015 
1016 
1017 
1018 
1019 
1020 
1021 
1022 
1023 
1024 
1025 
1026 
1027 
1028 
1029 
1030 
1031 
1032 
1033 
1034 
1035 
1036 
1037 
1038 
1039 
1040 
1041 
1042 
1043 



GLOBAL 

wrdbcd PROCEDURE 

{ll»»»»»»»)l««»»fll»»»4lt»»»»«ll»«»»»»»il«««»ll«llftll»«§lfft»«ll«ll 

Purpose = To convert a signed binary word 
to a variable length BCD string. 

Input s R14 = address of destination BCD 

string (in register memory) 
RR12 = source binary word 
R15 = BCD digit count / 2 

Output = BCD string in destination buffer 
Carry FLAG = 1 if dest overflow 

= if no error . 
R12,R13,R1M,R15 modified. 



ENTRY 



wrd bO: 



wrd b1 : 



clr 
tm 
jr 
or 
com 
com 
add 
adc 
rlc 
rlc 
inc 
Id 
Id 
add 
dec 
_ clr 
inc 
djnz 
Id 
wrd b3: push 
rlc 
rlc 
Id 
Id 
bed, str 
Id 
adc 
da 
Id 
dec 
djnz 
pop 
jr 
dec 
jr 
ret 
wrdbcd 



Kdest 
wrd b2: 



wrd ex: 

END" 



§bcd adr 
R12,?%80 
z,wrd bO 
@bcd_adr,#%80 

R13 
R12 
R13,<H 
R12,y/0 
R13 
R12 

bed adr 

TEMF__1,bcd_adr 
TEMP 2, bed cnt 
TEMP;;;i,bcd~cnt 
TEMP_1 
§bcd__adr 
bcd__adr 

bcd_cnt,wrd_b1 
TEMP 3, #15 
TEMP~3 
R13 
R12 

bed adr, TEMP 1 
bed"cnt,TEMP~2 
ing) 7 — (dest bed 
TEMP_3,@bcd__adr 
TEMP 3,§bed adr 
TEMP"3 

§bcd_adr,TEMP_3 
bcd__adr 

bed cnt, wrd b2 
TEMF_3 
c,wrd ex 
TEMP_I 
nz,wrd b3 



init sign/post_dec cnt! 
is input word negative? 



Iset result negative! 



!RR12 two's complement! 



bit 15 not magnitude! 
update dest pointer! 



!dest byte count! 



= bed end addr! 
initialize dest! 



! source bit count! 



!bit 15 to carry! 
! start at end! 
!dest byte count! 
string * 2) + carry! 

!* 2 + carry! 



!next two digits! 
!loop for all digits! 
!restore sre bit cnt! 
!dest. overflow! 

!next bit! 
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p 0319 



0319 BO 
03IB BO 
03ID BO 
03IF D6 
0322 7B 
032U D6^ 
0327 7B 
0329 A6 
032c 3B 
032E 26 



0331 FO 
0333 D9 
0335 56 
0338 56 
033B ^H 
033E FO 
03^0 56 
0343" 56 
03^6 
03^9 
034B CF 
03^C AF 
03UD 



mi 
8B 



7E 

EC 

ED 

03DA» 

28 

onoD' 

22 

7C 39 

03 

7C 37 



ED 

7D 

ED FO 

7C OF 

7C ED 

EC 

EC FO 

7D OF 

7D EC 



1045 
1046 
1047 
1048 
1049 
1050 
1051 
1052 
1053 
1054 
1055 
1056 
1057 
1058 
1059 
1060 
1061 
1062 
1063 
1064 
1065 
1066 
1067 
1068 
1069 
1070 
1071 
1072 
1073 
1074 
1075 
1076 
1077 
1078 
1079 
1080 
1081 
1082 
1083 
1084 
1085 
1086 
1087 
1088 
1089 
1090 
1091 
1092 



GLOBAL 

hascwrd PROCEDURE 

Purpose s To convert a variable length Hex 
ASCII string to binary. 



Input = 



RR14 



address of source ASCII 
string (In reg/ext/ser memory), 



Output = RR12 5 binary word (any overflow 
high order digits are truncated 
without error). 
Carry FLAG = 1 If Input error 

(serial only) 
(SER__flg indicates cause) 
r if no error 
R14, RI5 modified 

Note r The ASCII input string processing is 
terminated with the occurrence of a 
non-hex ASCII character." 



ENTRY 



clr TEMP_3 
clr R12 
clr RI3 
has_c1: call get_src 

jr c,has_ex1 
call ver^asc 
jr c,has_ex 
cp TEMP 1,//$39 
jr ule,!fas_c2 

sub TEMP 1,//%37 / 

left one nibble! 
new nibble in least significant nibble! 



!inlt output! 

!get input! 

ferror! 

!verify hex ASCII! 

!end conversion! 



! Shift 
!Insert 
has c2: 



has^ex : 
has'^exl 
END~ 



swap 
Id 
and 
and 
or 

swap 
and 
and 
or 
Jr 
rcf 
;ret 
hascwrd 



RI3 
TEMP 2,R13 
/R13,?%F0 
TEMP 1,//%0F 
R13,TEMP_1 
R12 

R12,//%F0 
TEMP 2,#$0F 
R12,TEMP_2 
has c1 



!loop! 
!no error! 
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1094 GLOBAL 

P OBMD 1095 dascwrd PROCEDURE 

1096 !*«»»»*)»»»»»»»»»»»»)(*)(»»»«»*«*»*»»»««*»»»»»»*»«»»«»»»« 

1097 Purpose = To convert a variable length decimal 

1098 ASCII string to signed binary. 
1099 

1100 Input = RRIM = address of source ASCII 

1101 string (in reg/ext/ser memory). 

1102 - 

1103 Output = RR12 = binary word 

1104 R8,R9,R10,R11 holds the packed BCD 

1105 version of the result. 

1106 Carry FLAG = 1 if input error 

1107 (serial only) 

1108 (SER__flg indicates cause) 

1109 or dest overflow 

1110 = if no error 

1111 RIM, R15 modified 
1112 

1113 Note = The ASCII input string processing is 

1114 ^ terminated with the occurrence of a 

1115 non-decimal ASCII character. 

1116 Decimal ASCII string may be no more 

1117 than 6 digits in length, else Carry 

1118 will be returned. 

1119 Post decimal digits are not included 

1120 in the binary result.. 

1121 »»«t»ii««»f»»««»»»«»i»»»»»»»»«»»ii»ii»««»if«»»«»»»»«»»»ft»«{ 

1122 ENTRY 

P 034D CC 03 1123 Id R12,//3 16 digits! 

P 034F DC 08 1124 Id R13,#8 !temp addr =! 

P 0351 04 FD ED 1125 add R13,RP ! R8 thru R11! 

P 0354 D6 0363' 1126 call dascbcd fconvert to bed! 

P 0357 7B F3 1127 jr c,has_ex1 !error! 

P 0359 EC 08 1128 

P 035B 04 FD EE 1129 

P 035E FC 03 1130 

P 0360 8D 0284» II3I jp bcdwrd !convert to binary! 

P 0363 1132 END 



Id 


R12,//3 


Id 


R13,#8 


add 


R13,RP 


call 


dascbcd 


jr 


c,has exi 


Id 


R14,#^ 


add 


R14,RP 


Id 


Rl5,y/3 


jp 


bcdwrd 


dascwrd 
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P 0363 



0363 70 
0365 70 
0367 B1 

0369 DE 
036A CA 
036C B1 
036E 50 

0370 50 
0372 E6- 
0375 BO 



0377 D6 
037A 7B 
037C 56 
037F 76 
0382 EB 
0384 A6 
0387 6B 
0389 A6 
038C EB 
038E B7 
0391 8B 
0393 5B 
0395 A6 
0398 EB 
039A 116 
039D 8B 
039F D6 
03A2 7B 
03A4 i\6 
03A7 D6 
03AA EB 
03AC 76 
03AF 6B 



EC 
ED 
ED 

FB 

ED 

ED 

EC 

7E 01 

7B 



03DA» 

41 

7C 7F 

7B 03 

OF 

7C 2B 

EE 

7C 2D 

07 

ED 80 

E4. 

OA 

7C 2E 

05 

7B 03 

D8 

040D' 

16 

7B 01 

0463* 

09 

7B 02 

C6 



1134 CONSTANT 

1135 dab_LEN 

1136 dab_DST 

1137 GLOBAL 

1138 dascbcd PROCEDURE 



R12 
R13 



j»»»»«»«»»»»»»»»«»»»»»»»«»»»«««»»««)f»K»»»»»«»»««»)|ll««)( 



Purpose s 



Input 



Output = 



Note 



1139 

1140 

1141 

1142 

1143 

1144 

1145 

1146 

1147 

1148 

1149 

1150 

1151 

1152 

1153 

1154 

1155 

1156 

1157 

1158 

1159 

1160 

1161 

1162 

1163 

1164 

1165 das g1 

1166 

1167 

1168 

1169 

1170 

1171 

1172 

1173 

1174 

1175 das_g2: call 

1176 jr 

1177 and 

1178 tm 

1179 jr 

1180 cp 

1181 jr 

1182 cp 

1183 jr 

1184 xor 

1185 jr 

1186 das g5: jr 

1187 das g4: cp 
1188 



To convert a variable length decimal 
ASCII string to BCD. 

R13 = address of destination BCD 

string (in register memory). 
RR14 = address of source ASCII 

string (in reg/ext/ser memory). 
R12 = BCD digit count / 2 

BCD string in designated destination 
buffer (any overflow high order 
digits are truncated without error). 
Carry FLAG = 1 if input error 

(serial only) 
(SER_flg indicates cause) 
or overflow 
R14, R15 modified. 



The ASCII input string processing is 
terminated with the occurrence of a 
non-decimal ASCII character. 

»««»»»«»»«»«»»« »»»««»»»«»»»» »««»»«»«««»««« ]f««««4f«ll«IIK, 

ENTRY 

dab LEN 

dab~DST 

@dab DST 

dab_UST 

dab LEN, das g1 

§daF DST 



push 

push 

clr 

inc 

djnz 

clr 

pop 

pop 

Id 

clr 



1189 
1190 
1191 
1192 
1193 
1194 
1195 
1196 
1197 



das__g6: 



jr 

or 

Jr 

call 

jr 

or 

call 

jr 

tm 

jr 



! save! 

!init. destination! 



dab DST 
dab~LEN 
TEM7 3,#1 
TEMP"'4 



get_src 

c jdab__ex1 

TEMP 1,#%7F 

TEMP_4,#$d3 

nz,das g5 

TEMP__1,#'+' 

z,das_g2 

TEMP__1,#'-» 

nz,das g4 

§dab_D^T,#%80 

das g2 

mijH'as g6 

TEMP___1,y/'.» 

nzydas g6 

TEMP_4,y/%03 

das_g2 

ver__asc 

c ,dab__ex 

TEMP 4,//$01 

rdl " 

nzjdas g7 

TEMP_47//%02 

z,das_g2 



!init.! 
! restore! 

! f or ver asc! 

!bit =y digit seen; 

bit 1 => dec pt seen; 

bit 7 => overflow! 
iget input byte! 
!serial error! 
! 7-bit ASCII! 
!check status! 
!sign char not valid! 
!positive?! 
!yes. no affect! 
!negative?! 
!not sign char! 
!complement sign! 
!get next input! 
!dec pt has been seen! 
!is char dec pt?! 
!nope.! 

!dec pt and digit seen! 
!get next input! 
!is bed digit?! 
!end conversion,! 
! digit seen! 
!new digit to dest! 
!overflow! 
!post dec digit?! 
!no. get next input! 
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P 03B1 21 ED 

P 03B3 8B C2 

P 03B5 46 IB 

P 03B8 8B BD 



P 03BA EU 
P 03BD AF 
P 03BE 



P 03BE 



03BE 70 
03C0 70 
03C2 EC 
03CU OM 
03C7 FC 
03C9 D6 
03CC 50 
03CE 50 
03D0 CC 
03D2 DC 
03D4 OM 
03D7 8D 
03DA 



80 



7B FC 



EE 

EF 

08 

FD 

03 

02CD 

EF 

EE 

03 

08 

FD 

0205 



EE 



ED 



1198 

1199 

1200 das g7: 

1201 

1202 

1203 dab ex; 

120M dab^exl; 

1205 END" 



inc 
jr 
or 
jr 

Id 
ret 



@dab__DST 
das g2 
TEMP_U,#%80 
das_g2 

FLAGS, TEMP 4 



line post dec cnt! 

!get next input! 

! set overflow! 

!get next input! 

!carry s or 1 ! 



dascbcd 



1207 
1208 
1209 
1210 
1211 
1212 
1213 
1214 
1215 
121,6 
1217 
1218 
1219 
1220 
1221 
1222 
1223 
1224 
1225 
1226 
1227 
1228 
1229 
1230 
1231 
1232 
1233 
1234 
1235 



GLOBAL 

wrddasc PROCEDURE 

{««»»tt»)iii»t»«»»«»»»««iiii«»ii»f«»»««»i»»«»ii»«t»ii»»»»»»)i«»« 

Purpose = To convert a signed binary word to 
decimal ASCII 



Input s 



Output = 



RR12 = source binary word. 
RR14 s address of dest (in reg/ext/ser 
memory) . 



Decimal ASCII in dest buffer. 
R8,R9,R10,R11 holds the packed BCD 
version of the result. 
R12, R13, R14, R15 modified. 

ENTRY 



!save dest addr! 

!R8,9,10 & 11 temp! 
!temp byte length! 
! convert input word ! 

! restore dest addr! 
! length of temp! 

!addr of temp! 

! convert to ASCII! 



END 



push 


R14 




push 


R15 




Id 


R14, 


,y/8 


add 


R14, 


,RP 


Id 


R15, 


,//3 


call 


wrdbcd 


pop 


R15 




pop 


R14 




Id . 


R12, 


>#3 


Id 


R13, 


,#8 


add 


R13, 


,RP 


JP 


bcddasc 


wrddasc 
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P 03DA 



03DA CF 
03DB EE 
03DC EA 
03DE FE 
03DF FA 
03E1 8D 
03E4 70 
03E6 82 
03E8 B9 
03EA 50, 
03EC AO 
03EE AF 
03EF E5 
03F2 FE 
03F3 AF 
03FM 



P 03F1I 



03Fi| EE 
03F5 EA 
03F7 FE 
03F8 FA 
03FA 8D 
03FD 70 
03FF B8 
OilOl Q2 
0403 50 
0405 AO 

0407 AF 

0408 F5 
040B FE 
040C 
040D 



06 

OE 

0000* 

EB 

BE 

7C 

EB 

EE 

EF 7C 



06 

OE 

0000* 

EB 

7C 

BE 

EB 

EE 

7C EF 



AF 



1237 
1238 
1239 
1240 
1241 
1242 
1243 
1244 
1245 
1246 
1247 
1248 
1249 
1250 
1251 
1252 
1253 
1254 
1255 
1256 
1257 
1258 
1259 
1260 
1261 
1262 
1263 
1264 
1265 
1266 
1267 
1268 
1269 
1270 
1271 
1272 
1273 
1274 
1275 
1276 
1277 
1278 
1279 
1280 
1281 
1282 

1283 
1284 
1285 
1286 
1287 
1288 
1289 



GLOBAL ^ Ifor PART II only! 
get src PROCEDURE 

Purpose = To get source byte from 

reg/ext/ser memory into TEMP^I. 



Output s 



if error (serial) 
if all ok 
byte . 



Carry FLAG s 1 
= 
TEMP_1 s source 
RR14 updated. 

ENTRY 

! set good return code! 

!test R14 = 0! 

!src in ext memory! 

!test R15 = 0! 

! src in reg memory! 
_ ! src in ser memory! 

get_s1: push R11 __ ! save user's! 

!get byte! 

!move to common! 

!restore user's! 

! update src ptr! 

get_s2: Id TEMP_1,§R15 !get byte! 

!update src ptr! 
ret 
END 

GLOBAL !for PART 11 only! 

put dest PROCEDURE 

Purpose = To store destination byte from TEMP__1 
into reg/ext/ser memory 

Output = RR14 updated. 

ENTRY 



rcf 




inc 


R14 


djnz 


R14,get si 


inc 


R15 


djnz 


R15,get s2 


JP 


ser get 


push 


R11 


Ide 


R11,@RR14 


Id 


TEMP 1,R11 


pop 


R11 "" 


incw 


RR14 


ret 




Id 


TEMP 1,§R15 


inc 


R15 "" 


ret 




get src 





put_s1 ; 

put__s2: 
END 



inc 
djnz 
inc 
djnz 

JP 

push 

Id 

Ide 

pop 

incw 

ret 

Id 

inc 

ret 

put dest 



R14 

R14,put_s1 

R15 

Rl5,put_s2 

ser output 

R11"" 

R11,TEMP 1 

§RR14,R1T 

R11 

RR14 

@R15,TEMP__1 
R15 



!test R14 = 0! 

!dest in ext memory! 

!test R15 = 0! 

!dest in reg memory! 

!dest in ser memory! 

!save user's! 



!restore user's! 
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1291 


CONSTANT 














1292 


MODE 




:= TEMP 3 












1293 


char 




:= TEMP_1 












1294 


INTERNAL 






P OUOD 








1295 


ver asc 


PROCEDURE 












1296 


!«»T»»»ft«»»»»ii»«»»»tt»»ft»»»ii»«»»»iiii»«»ii»»»»»«»««»«»ji»ftii 










1297 


Purpose = 


To verify input 


; character as valid 










1298 






hex or decimal 


ASCII. 










1299 


















1300 


Input 


= 


TEMP 1 = 8-bit 


input 










1301 






TEMP 3 = => test for hex, 










1302 






1 => t 


;est for decimal 










1303 


















1304 


Output 


= 


Carry FLAG = 


if no error 










1305 






1 


if error. 










1306 


«««»»««»»««»«»»«)i»ii»»»«»ii»»«««»»»«»«ft»)f««»»»«ft«««»»ii»{ 










1307 


ENTRY 








P OMOD 


56 


7C 


7F 


1308 




and 


ehar,#$7F 


!7-bit ASCII! 


p omo 


A6 


7C 


30 


1309 




CP 


char ,#'0' 


1 range start: '0'! 


P 0M13 


7B 


16 




1310 




jr 


ult,ver err 


!no good! 


P 0U15 


A6 


7C 


3A 


1311 




ep 


ehar,#»9'+1 


!dec range end: '9'! 


P 0418 


7B 


10 




1312 




jr 


ult,ver ok 


!all»s well! 


P 0U1A 


76 


7E 


01 


1313 




tm 


M0DE,#1~ 


!dec or hex?! 


P 041D 


EB 


OB 




1314 




jr 


nz,ver ere 


!no good! 


p oniF 


56 


7C 


DF 


, 1315 




and 


ehar,#rN0T( 'a'- 


.♦A') !insure upper ease! 


P 0422 


A6 


7C 


41 


1316 




ep 


ehar,y/'A» 


!check A-F range! 


P 0425 


7B 


04 




1317 




Jr 


ult,ver err 


!no good! 


P 0427 


A6 


7C 


47 


1318 
1319 


ver_ok: 


ep 


ehar,#'F'+1 


!end hex range! 


P 042A 


EF 






1320 


ver ere 


: ccf 




! complement carry! 


P 042B 


AF 






1321 


ver err 


: ret 






P 042C 








1322 


END 


ver_asc 














1324 


INTERNAL 






P 042C 








1325 


bed bin 


PROCEDURE 












1326 


! »»7««»)i»»»»ft»)(»«««»««»»»«ii»«»»»«»ii»»»)i»i(»x«»«»»»»»ii«» 










1327 


Purpose = 


To convert next 


i bed digit to binary. 










1328 


















1329 


Input 


= 


TEMP_1 = digit 












1330 


















1331 


Output 


= 


RR12 = RR12 » 10 + digit 










1332 


»«»»»»)ift«»)i»»]f»»»»»««»»«»««««»»»ii»»«i(«»»»«»»»»»»«»i»»«t 










1333 


ENTRY 








P 042C 


56 


7C 


OF 


1334 




and 


TEMP 1,#%0F 


! isolate digit! 


P 042F 


A6 


7C 


09 


1335 




CP 


TEMP 1,#9 


!verify valid! 


P 0432 


BB 


2D 




1336 




jr 


ugt,Fed b1 


! error ! 


P 0434 


02 


DD 




1337 




add 


R13,R13" 




P 0436 


12 


CC 




1338 




ado 


R12,R12 


!2x! 


P 0438 


7B 


27 




1339 




jr 


c,bed b1 


!overflow! 


P 043A 


70 


EC 




1340 




push 


R12 




P 043C 


70 


ED 




1341 




push 


R13 




P 043E 


02 


DD 




1342 




add 


R13,R13 




P 0440 


12 


CC 




1343 




ade 


R12,R12 


!4x! 


P 0442 


7B 


19 




1344 




jr 


e,bcd b2 


!overflow! 


P 0444 


02 


DD 




1345 




add 


R13,RT3 




P 0446 


12 


CC 




1346 




ade 


R12,R12 


!8x! 


P 0448 


7B 


13 




1347 




jr 


e,bed b2 


!overflow! 


P 044A 


04 


7C 


ED 


1348 




add 


R13,TEMP 1 




P 044D 


16' 


EC 


00 


1349 




ade 


R12,y/0 "" 


!8x + d! 


P 0450 


7B 


OB 




1350 




jr 


e,bed b2 


!overflow! 


P 0452 


50 


7C 




1351 




pop 


TEMP T 




P 0454 


04 


7C 


ED 


1352 




add 


R13,TEMP 1 




P 0457 


50 


7C 




1353 




pop 


TEMP 1 - 




P 0459 


14 


7C 


EC 


1354 




ade 


R12,TEMP_1 


!10x + d! 


P 045C 


AF 






1355 
1356 




ret 






P 045D 


50 


7C 




1357 


bcd_b2: 


pop 


TEMP 1 




P 045F 


50 


7C 




1358 




pop 


TEMP 1 


!restore stack! 


P 0461 


DF 






1359 


bed b1 : 


sef 




! error! 


P 0462 


AF 






1360 


, 


ret 






P 0463 








136I 


END 


bod bin 
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1363 


CONSTANT 














1364 


s len 




: r R 1 2 












1365 


s adr 




:= R13 












1366 


INTERNAL 




p 


0463 








1367 


rdl 


PROCEDURE 












1368 


I»1l««»»»««»)l«»»»»»ll«4ltt»»»»ll«»]l«»»»»»«ll»«»»»X»» »»»»»»»« 












1369 


Rotate 


Digit 


Left 












1370 


















1371 


Input 


: 


R12 s BCD string length 












1372 






R13 = BCD string address 












1373 






TEMP_1 bit 3-0 = new digit 












1374 


















1375 


Output 


s 


BCD string rotated left one digitj 
new digit inserted in units position. 












1376 
















1377 






TEMP 1 bit 3-0 = digit rotated out 












1378 






of high order digit position 












1379 






bit 7-4 = 












1380 






Zero FLAG r 1 if TEMP 1 <> 












1381 






R12, R13 unmodified 












1382 


)i»«ii»«»«ii»»«»»if«»»ii«ii«»»»««ii»iiii)i»ii«»«»»»»»ii»ii»iiii«»««»{ 












1383 


ENTRY 






p 


0463 


70 


EC 




1384 




push 


s_lenr 


p 


0465 


02 


DC 




1385 




add 


s adr,s len laddress of units plac( 


p 


0467 


F1 


ED 




1386 


rdl 01: 


swap 


@s adr 


p 


0469 


E5 


ED 


7D 


1387 




Id 


TEMP 2,§s adr 


p 


046C 


57 


ED 


FO 


1388 




and 


§s a3'r,#^F0 1 isolate digit! 


p 


046F 


56 


7C 


OF 


1389 




and 


TEMP ^,n0F ! isolate new digit! 


p 


0472 


^^5 


ED 


7C 


1390 




or 


TEMP~1,§s_adr 


p 


0475 


F5 


7C 


ED 


1391 




Id 


@s adr, TEMP 1 !save new byte! 


p 


0478 


E4 


7D 


7C 


1392 




Id 


TEKP 1,TEMP~2 


p 


047B 


00 


ED 




1393 




dec 


s adr !back-up pointer! 


p 


047D 


CA 


E8 




1394 




djnz 


s len, rdl 01 !loop till done! 


p 


047F 


56 


7C 


OF 


1395 




and 


TIMP 1,//%0F !old high order digit! 


p 


048.2 


50 


EC 




1396 




pop 


s len !restore R12! 


p 


0484 


AF 






1397 




ret 


. 


p 


0485 








1398 


END 


rdl 














1400 


INTERNAL 




p 


0485 








1401 


rdr 


PROCEDURE 












1402 


!«««)i»««»»«»»»«»»»ii»»»»««»»»ii»»»»»»»»»«»»»»»»««»«»«««ii 












1403 


Rotate 


Digit 


Right 












1404 


















1405 


Input 


= 


R12 = BCD string length 












1406 






R13 = BCD string address 












1407 






TEMP 1 bit 7-4 = new digit 












1408 






■ 












1409 


Output 


= 


BCD string rotated right one digit; 












1410 






new digit inserted in high order 












1411 






position . 












1412 






R12 unmodified 












1413 






R13 modified 












1414 


ii»«»»«»»»»»»»»»)i»»»»ii»ii»»»»«»»i»»»ii»)i»«»»» »»»»»»»»»«»«! 












1415 


ENTRY 








0485 


70 


EC 




1416 




push 


s len 




0487 


DE 






1417 


rdr__01: 


inc 


s adr 




0488 


F1 


ED 




1418 




swap 


@s adr 

TET^P 3,§s adr 




048A 


E5 


ED 


7E 


1419 




Id 




048D 


57 


ED 


OF 


1420 




and 


§s aZr.H'SF ! isolate digit! 




0490 


56 


7C 


FO 


1421 




and 


TEMP 1,#%F0 iisolate new digit! 




0493 


45 


ED 


7C 


1422 




or 


TEMP"~1,@s adr 




0496 


F5 


7C 


ED 


1423 




Id 


@s adr, TEMP 1 !save new byte! 




0499 


E4 


7E 


7C 


1424 




Id 


TERP 1,TEMP"3^ 




049C 


CA 


E9 




1425 




djnz 


s len, rdr 01 !loop till done! 




049E 


50 


EC 




1426 




pop 


s len !restore R12! 




04A0 


AF 






1427 




ret 


, 


p 


04A1 








1428 


END 


rdr 
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Bit Manipulation Routines 



P 0UA1 



p 


0UA1 


E6 


7C 


p 


onkn 


BO 


7D 


p 


0MA6 


90 


EC 


p 


0MA8 


90 


ED 


p 


OMAA 


FB 


06 


p 


OUAC 


EO 


EC 


p 


04AE 


90 


EC 


p 


04B0 


10 


7D 


p 


0462 


00 


7C 


p 


0484 


EB 


FO 


p 


04B6 


C8 


7D 


p 


04B8 


AF 




p 


04B9 







08 



1460 
1461, 
1462 
1463 
1464 
1465 
1466 
1467 
1468 
1469 
1470 
1471 
1472 

1473 
1474 

1475 
1476 
1477 
1478 
1479 
1480 
1481 
1482 
1483 
1484 
1485 
I486 
1487 
1488 
1489 
1490 
1491 
1492 
1493 
1494 
1495 
1496 
1497 



CONSTANT 

tjm_bits := R12 

tjm mask := R13 
GLOBiL 
clb PROCEDURE 

Purpose = To collect selected bits in a byte 
into adjacent bits in the low order 
end of the byte. Upper bits in byte 
are set to zero. 



Input = 

Output 
Note = 



R12 = input byte 

R13 = mask. Bit = 1 => corresponding 
input bit is selected. 



R12 



collected bits 



For example: 

Input : R12 = %(2)01110110 
R13 = %(2)10000101 



Output : R12 = %(2)d0000010 

ENTRY 

TEMP 1,#8 

TEMP_2 

tjm_bits 

tjm_mask 

nc ,no select 

tjm_bTts 

tjm bits 

TEM"? 2 



nextl : 



Id 

clr 

rl 

rl 

jr 

rr 

rl 

rlc 

no_select : 
dec 
jr 
Id 
ret 

END clb 



!bit count! 
!bits collected here! 
!bit. 7 to bit 0! 
!bit 7 to carry! 
!don't use this bit! 



!bit 7 to and carry! 
!collect source bit! 



TEMP__1 
nz, nextl 
R12,TEMP_2 



irepeat! 
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P 04B9 



04B9 D6 
O^BC 02 
onBE 16 
OilCI 02 
OilC3 16 
0406 02 
0408 AO 
04CA 02 
0400 E8 



04A1 

CO 

EE 

FO 

EE 

DE 

EE 

FE 

ED 



00 



00 



P 04CE 30 EE 
P '04D0 



1499 
1500 
1501 
1502 
1503 
r504 
1505 
150.6 
1507 
1508 
1509 
1510 
1511 
1512 
1513 
1514 
1515 
1516 
15,17 
1518 
1519 
1520 
1521 
1522 

1523 
1524 
1525 
1526 
1527 
1528 
1529 
1530 
1531 
1532 

1533 
1534 
1535 
1536 



R14 
R15 
RR14 



CONSTANT 

tjni_tabh 

tjm^tabl 

tjm tab 
GLOBiL 
tjm PROCEDURE 

Purpose = To take a jump to a routine address 
determined by the state of selected 
bits in a source byte. A bit 
is ♦selected* by a one in the 
corresponding position of a mask. 
The 'selected' bits are packed into 
adjacent bits in the low order end of 
the byte. This value is then doubled, 
and used as an index into the jump 
table. 



Input 



RR14 



address of jump table in 
program memory. 
R12 = input data 
R13 s mask 

ENTRY 

clb fcollect selected bits! 

tjm__bits,tjm_bits !collected bits » 2! 

tjm_tabh,#0 !in case carry! 

tjm_tabl ,tjm_bits 

tjm_tabh,#0 !tjm_tab points to.. 

tjpfi_mask,@tjm_tab !... table entry! 

tjm__tab 

tjm_tabl ,@tjm_tab !get table entry.. 

tjm tabhjtjm mask !...into tjm_tab!' 



call 

add 

adc 

add 

adc 

Idc 

incw 

Idc 

Id 



JP 

END tjm 
END PART I 



.! 



.! 



§tjm tab 



!bye! 



errors 
Assembly complete 
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ROMLESS Z8 SUBROUTINE LIBRARY PART II 



Z8ASM 3. 


02 








LOG OBJ CODE STMT SOURCE STATEMENT 




2 

3 PART II MODULE 




5 

6 !• ROMLESS 

7 ! 

9 CONSTANT 


Z8' SUBROUTINE LIBRARY PART II 








10 ! Register 


Usage! 




11 






12 RAM START 


:= , %7F 




13 






1M P3M save 




= RAM START 




15 TEMP 3 




•= P3M save-1 




16 TEMP~2 




r TEMP 3-1 




17 TEMP"1 




TEMP 2-1 




18 TEMP^ii 




TEMP"~1-1 




19 


~" 




20 !The following registers are modified/referenced 




21 by the Serial Routines ONLY. They are 




22 available 


as general registers to the user 




23 who does i 


lot intend to make use of the 




24 Serial Routines! 




25 






26 SER char 




TEMP 4-1 




27 SER tmp2 




SER char-1 




28 SER~tmp1 




= SER tmp2-1 




29 SER put 




= SER'"tmp1-1 




30 SER len 




= SER put-1 




31 SER buf 




SER'~len-2 




32 SER"imr 




SER buf-.1 




33 SER cfg 




= SER'~imr-1 




34 ! Serial Configuration Data 




35 bit 7 : =1 


=> odd parity on 




36 bit 6 : =1 


=> even parity on 




37 (bit 6,7 


= 11 => undefined) 




38 bit 5 : undefined 




39 bit 4 : undefined 




40 bit 3 : =1 


=> input editting on 




41 bit 2 : =1 


=> auto line feed enabled 




42 bit 1 : =1 


=> BREAK detection enabled 




43 bit : =1 


=> input echo on 




44 ! 






45 op 


r 


$80 




46 ep 


:r 


%40 




47 ie 


,= 


%0S 




48 al 


: = 


%04 




49 be 


= 


%02 




50 ec 


: : 


%0^ 




51 SER get 


:= SER cfg-1 




52 SER~flg 


:= SER get-1 




53 ! Serial Sts 


jtus Flags 




54 bit 7 : =1 


=> serial I/O disabled 




55 bit 6 : unc 


efined 




56 bit 5 : unc 


efined 




57 bit 4 : =1 
56 bit 3 : =1 


=> parity error 




=> BREAK detected 




59 bit 2 : =1 


=> input buffer overflow 




60 bit 1 : =1 


=> input buffer not empty 




61 *bit : r1 


=> input buffer full 




62 ! 






63 sd 


= 


%B0 




64 pe 


= 


%10 




65 bd 


= 


%0B 




66 bo 


s 


%04 




67 bne 


r 


%02 




68 bf 


= 


%0^ 




69 
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SERltime 
SERhtime 



70 RAM TMR 

71 

72 

73 

7^ 

75 

76 

77 

78 

79 

80 

81 TOD tic 

82 TOD~imr 

83 TOD~hr 
8^ TOD_min 

85 TOD sec 

86 TOD tt 

87 PLS31 
PLS tmr 



RAM_START-%10 

SER flg-1 
SERltime-1 



!The following registers are modified/referenced 
by the Timer/Counter Routines ONLY. They are 
available as general registers to the user 
who does not intend to make use of the 
Timer/Counter Routines! 



RAM TMR-2 
T0D~tic-1 
TOD imr-l 
TODHir-l 
T0D_min-1 
T0D_sec-1 
TOD tt-1 
PLS~1-1 
PLS tmr-1 



! Equivalent working register equates 
for above register layout! 



88 
89 
90 

91 RAM^END := PLS 2 

92 STACK :r RAM~END 
93 
9M 
95 
96 

97 iregister file %70 - $7F! 

98 RAM STARTr := ^70 ! f or SRP! 
99 

100 rP3Msave :s R15 

101 rTEMP__3 := RU 

102 rTEMP 2 := R13 

103 rTEMP^I := R12 

104 rrTEMP 1 := RR12 

105 rTEMP_Th := R12 

106 rTEMP 11 := RI3 

107 rTEMp-M := R11 

108 rSERcFar := RIO 

109 rSERtmp2 := R9 

110 rSERtmpI := R8 

111 rrSERtmp := RR8 

112 rSERtmpl := R9 

113 rSERtmph := R8 
m rSERput :r R7 

115 rSERlen := R6 

116 rrSERbuf := RRi| 

117 rSERbufh := Ri| 

118 rSERbufl := R5 

119 rSERimr := R3 

120 rSERcfg :s R2 

121 rSERget :s Rl 

122 rSERflg :c RO 
123 

124 

125 !register file %60 

T26 RAM TMRr :r %60 ! for SRP! 

127 

128 

129 



!register 
RAM TMRr 
rTOTJtic 
rTODimr 
rTODhr 

130 rTODmin 

131 rTODsec 

132 rTODtt 

133 rPLS_1 

134 rPLStmr 

135 rPLS 2 



%6F! 
*60 
RI3 
R12 
R11 
RIO 
R9 
R8 
R7 
R6 
R5 
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Serial Routines 



P 0000 



p 


0000 


EE 




p 


0001 


EA 


04 


p 


0003 


EC 


00* 


p 


0005 


FC 


51» 


p 


0007 


BC 


72 


p 


0009 


DC 


05 


p 


OOOB 


C3 


BE 


p 


OOOD 


DA 


FC 


p 


OOOF 


56 


73 



Output = 



F7 



164 CONSTANT 

165 si_PTR 

166 si TMP1 

167 3i TMP2 

168 GLOBAL 

169 ser init 

170 t««iF»»«»»»«ii« 

171 serial initia 
172 

173 Purpose = 
174 
175 
176 
177 

178 Input = 
179 
180 
181 
182 
183 
184 
185 
186 
187 
188 
189 
190 
191 
192 
193 
194 

195 Note = 
196 
197 
198 
199 
200 
201 
202 

203 
204 
205 
206 
207 
208 
20.9 
210 
211 
212 
213 
214 

215 

216 »«»»»«*»»»»*» 

217 ENTRY 

inc 

djnz 

Id 

Id 

Id 

Id 

Idci 
djnz 
and 



RR14 

R11 

R13 



218 

219 

220 

221 

222 si__1 

223 

224 si 2 

225 ' " 
226 
227 



PROCEDURE 

lize 

To initialize the serial channel and 
RAM flags for serial I/O. Serial 
input occurs under interrupt control. 
Serial output occurs in a polled mode. 

RR14 r address of parameter list in 

program memory (if R14 r 0, 

use defaults) : 
1 byte = Serial Configuration Data 

(see definition of SER_cfg) "^ 
1 byte = IMR mask for nestable 

interrupts 
1 word = address of circular input 

buffer (in reg/ext memory) 
1 byte = Length of input buffer 
1 byte = Baud rate counter value 
1 byte = Baud rate prescaler value 
(unshifted) 

Serial I/O operations initialized. 
R11, R12, R13, R1^, R15 modified. 

Defaults; 
Input echo on 
Input editting oh 
BREAK detection enabled 
No parity 
Auto line feed on 
Input Buffer Address = SER_char 
Input buffer length = 1 byte 
Baud Rate = 9600 (assuming 
XTAL = 7.3728 MHz) 

The instruction at %0809 must result 
in a jump to the jump table entry for 
ser_input . 

If BREAK detection is disabled, and a 
BREAK occurs, it will be received as a 
continuous string of null characters. 

The parameter list is not referenced 
following initialization. 

R14 !use defaults?! 

R14,si__1 !no. given by caller.! 

R14,#HI ser_def !address of default...! 

R15,#L0 ser def !... parameter list. ! 

si TMP1,//SEl cfg 

si TMP2,#5 

@sT TMP1,§si_PTR !get initialization...! 

si__TMP2,si_2 !.. .parameters! 

SER_imr ,//$F7 ! insure no self-nesting! 
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0012 56 
0015 B8 
0017 56 
001A- i|6 
001D 56 
0020 44 
0023 'E4 



0026 BC 
0028 C2 
002A C3 
002C C2 
002E 
0031 
0033 D9 
0035 90 

0037 DF 

0038 10 
003A B9 



D6 
C9 



P 003C 8F 
P 003D BO 
P 003F BO 
P 0041 BO 



P 004D 46 
P 0050 AF 
P 0051 



F1 FC 
72 

EB 80 

EB 40 

7F 3F 

EB 7F 

7F F7 



F4 

DE 

BE 

BE 

0000» 

6E 

6F 

EB 



228 initialize Port 3 Mode Register for serial I/O! 
229 



EB 
F5 



71 
77 
70 



P 0043 56 FA 

P 0046 56 FB 

P 0049 46 FB 

P 004C 9F 



E7 
EF 
08 



F1 03 



P 0051 OF 00 
P 0053 007A 01 
P 0056 02 03 



AND 

Id 

AND 

OR 

AUD 

OR 

LD 

itialize TO! 
Id 
Idc 
Idci 
Idc 
call 
Id 
Id . 
rl 
scf 
rlc 
Id 



230 

231 

232 

233 

234 

235 

236 

237 !in 

238 

239 

240 

241 

242 

243 

244 

245 

246 

247 

248 

,249 !in 

250 DI 

251 clr SER get 

252 clr SER put 

253 clr SER fig 
254 

255 !initialize interrupts! 



TMR,#$FC !disable TO! 

si_TMP1,SER_cfg !configuration data! 

si_TMP1,#%80 !odd parity select! 

si TMP1,#%46 !P30/7 = Sin/Sout! 

P3'R save,y/%3F' !mask off old settings! 
P3Nrsave,si_TMP1 !new selection! 

P3M,P3M save !to write-only register! 



si TMP1,#T0 , 
si~TMP2,@si__PTR ! 
§si TMP1,§si PTR 
si_TMP1,§si_TTR ! 
multiply ! 
SERhtime,R12 ! 
SERltime,R13 ! 
si TMP1 , ! 



si TMP1 
PRE0,si TMP1 



save counter! 
!init counter! 
get prescaler! 
TO X PREO! 
save for BREAK. . , 
. . .detection 
SHL 1! 

continuous mode! 
SHL 2! 



itialize RAM flags and pointers! 



256 

257 

258 

259 

260 !go! 

261 

262 

263 END 

264 

265 

266 

267 !De 

268 

269 ser 



270 
271 
272 
273 



AND 
and 
or 
EI 

or 

ret 

ser init 



IRQ,#^E7 
IMR,#%EF 
IMR,//$08 



TMR,//%03 



!disable interrupts! 
! input buffer . . . ! 
! . . .empty! 
!no errors! 



!clear IRQ3 & 4! 
!disable IRQ4 (xmt)! 
!enable IRQ3 (rev)! 



!load/enable TO! 



faults for serial initialization! 
def RECORD [cfg , imr BYTE 



I 
_ ctr_, pre_ 
iec+al+ie+be, %00, SER char, 1, %02, %03] 



buf_ 
len 



WORD 
BYTE] 
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275 CONSTANT 

276 rli__len := R13 

277 GLOBAL 

P 0058 278 ser rlin PROCEDURE 

279 !**1F««******«*************** ******* ******************* 

280 read line 
281 

282 Purpose = To return input from serial channel 

283 up to 'carriage return' character or 

284 maximum length requested or BREAK. 
285 

286 Input = RR1M s address of destination buffer 

287 (i" reg/ext memory) 

288 R13 = maximum length 
289 

290 Output = Input characters is destination buffer. 

291 RR14 = unmodified 

292 R13 = length returned 

293 Carry Flag = 1 if any error, 

294 = if no error . 

295 R12 indicates read status 
296 

297 Note = 1. Return will be made to the calling 

298 program only after the requisite 

299 characters have been received from 

300 the serial line. 
301 

302 2. If input editting is enabled, a 

303 'backspace' character will cause 

304 the previous character (if any) in the 

305 the destination buffer to be deleted; 

306 a 'delete' character will cause all 

307 previous characters (if any) in the 

308 destination buffer to be deleted. 
309 

310 3* If parity, (odd or even) is enabled, 

311 the parity error flag (R14) will be set 

312 if any character returned had a parity 

313 error. (Bit 7 of each character may 

314 then be examined if it is desirable to 

315 know which character(s) had the error). 
316 

317 4. The status flags 'BREAK detected', 

318 'parity error', and 'input buffer 

319 overflow' will be returned 

320 as part of R12, but will be cleared in 

321 SER__stat. 
322 

323 5. The staus flags: 'input buffer full' 

324 and 'input buffer not empty' will be 

325 updated in SER stat. 

326 ******************************'>'**********************! 

327 ENTRY 

P 0058 BO 7E 328 clr TEMP__3 ! flag => read line! 

329 ser_read : 

P 005A 70 EE 330 push R14 !save original...! 

P 005C 70 EF 331 push R15 !...dest. pointer! 

P 005E 70 ED 332 push rli__len !...and length! 

P 0060 D6 0170' 333 rli_4: call ser_get !get input character! 

P 0063 7B 48 334 jr c,rli 3 !error! 

P 0065 76 72 CO 335 tm SER cTg,#op LOR ep ! parity enabled?! 

P 0068 6B 08 336 jr z,rTi_1 !no! 

P 006A 76 7C 80 337 tm TEMP_,1 ,//l680 ! parity error?! 

P 006D 6B 03 338 jr z»«"li_1 ^"oJ 
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P 006F U6 


70 


10 


339 


or 


SER_flg,//pe 


! yes. set error flag! 


P 0072 D6 


0000* 


340 rli 1: 


call 


put dest 


! store in buffer! 


P 0075 A6 


7E 


00 


341 


cp 


TEMP 3,//0 


!read line?! 


P 0078 EB 


31 




342 


jr 


nz,rTi 2 


!no! 


P 007A 56 


7C 


7F 


343 


and 


TEMP 1T//^7F 


! ignore parity bit! 


P 007D 76 


72 


08 


344 


tm 


SER cfg,#ie 


! input editting on?! 


P 0080 6B 


21 




345 

346 ! input 


jr 
edittin 


z,rTi 9 
g! 


!no.!- 


P 0082 A6 


7C 


7F 


347 


cp 


TEMP 1,#%7F 


!char = delete?! 


P 0085 6B 


3E 




348 


jr 


z,rlT 6 


!yes! 


P 0087 A6 


7C 


08 


349' 


cp 


TEMP ^,no8 


!char = backspace?! 


P 008A EB 


17 




350 


jr 


nz,rli 9 


!no , continue! 


P 008C 50 


7C 




351 


pop 


TEMP 1" 


!get original length! 


P 008E 70 


7C 




352 


push 


TEMP 1 




P 0090 A4 


ED 


7C 


353 


cp 


TEMP 1,rli len 


!any characters?! 


P 0093 6B 


30 




354 


jr 


eq,rli 6 ~ 


!none! 


P 0095 DE 






355 


inc 


rli len 


! undo last decrement! 


P 0096 26 


EF^ 


02 


356 


sub 


R15,y/2 


!backspace & previous! 


P 0099 -EE 






357 


inc 


R14 


!reg or ext mem?! 


P 009A EA 


02 




358 


djnz 


R14,rli 7 


!ext! 


P 009C 8B 


Q2 




359 


jr 


rli 4 ~ 


!reg! 


P 009E 36 


EE 


00 


360 rli 7: 


sbc 


R14,//0 




P 00A1 8B 


BD 




361 
362 


jr 


rli_4 




P 00A3 00 


ED 




363 rli 9: 


dec 


rli len 


! in case cr! 


P 00A5 A6 


7C 


OD 


364 


cp 


TEMP 1,#^0D 


!carriage return?! 


P 00A8 6B 


03 




365 


jr 


z,rli 3 


!end input! 


P OOAA DE 






366 


inc 


rli len 


! restore! 


P OOAB DA 


B3 




367 rli 2: 


djnz 


rli len, rli 4 


!loop for max length! 


P OOAD 50 


7C 




368 rli 3: 


pop 


TEMF 1 


!original length! 


P OOAF 24 


ED 


7C 


369 


sub 


TEMP 1,rli len 


!// chars returned! 


P 00B2 D8 


7C 




370 


Id 


rli len, TEMP 1 


!tell caller! 


P 00B4 C8 


70 




371 


Id 


R12,SER fig ~ 


ireturn read status! 


P 00B6 56 


70 


E3 


372 
373 


and 


SER_flg,//LNOT ( 


pe LOR bd LOR bo) 
!reset for next time! 


P 0^B9 CF 






374 


rcf 




!good return code! 


P OOBA 76 


EC 


9C 


375 


tm 


R12,//pe LOR bd 


LOR bo LOR sd 


P OOBD 6B 


01 




376 


jr 


z,rli 5 


!no error! 


P OOBF DF 






377 


scf 




! set error return! 


P OOCO 50 


EF 




378 rli 5: 


pop 


R15 




P 00C2 50 


EE 




379 


pop 


R14 


!original buffer addr! 


P 00C4 AF 






380 
381 


ret 






P 00C5 50 


ED 




382 rli 6: 


pop 


rli len 




P 00C7 50 


EF 




383 


pop 


R15 




P 00C9 50 


EE 




384 


pop 


R14 




P OOCB 8B 


8D 




385 


jr 


ser read 


! start over! 


P OOCD 






386 END 


ser_rlin 










:5«8 ULUBAL 








P OOCD 






389 ser rabs 


PROCEDURE 










390 1 »»¥»»»»««»»»««« »ii»ii !!»»»«»»»«» »»«»#««»»»»»»» ««»»»««»»» 








391 read absolute 












392 














393 Purpose = 


To return input 


from serial channel 








394 




of maximum length requested. (Input 








395 




is not terminated with the receipt of 








396 




a 'carriage return'. BREAK will 








397 




terminate read.! 


) 








398 














399 Note = 




All other details are as for 'ser rlin' 








400 »»»»»»»' 


»»»»»»»»»»»»»»»»»»»»»»» »»»»»»»»»»»»»»»»»»»1F»»»! 








401 £NTRY 








P OOCD E6 


7E 


01 


402 


Id 


TEMP 3,#1 


!flag => read absolute! 


P OODO 8B 


88 




403 


jr 


ser_read 




P 00D2 






404 END 


ser rab 


s 
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P 00D2 



00D2 EU 
00D5 70 
00D7 54 
OODA 9F 
OODB 70 
OODD 31 
OODF A8- 
O0E1 76 
OOEU 6B 
00E6 BO 
00E8 76 
OOEB 6B 
OOED 9C 
OOEF A2 
00F1 EB 
00F3 76 
00F6 EB 



P OOFS U6 
P OOFB 76 
P OOFE 6B 



03 78 

FB 

73 FB 

FD 

70 

FO 

E2 02 

2F 

E9 

E2 80 

02 

80 

A9 

22 

E8 01 

ID 

EO 08 
03 01 
FB 



P 0100 70 6E 

P 0102 70 6F 

P 010U 8C 35 

P 0106 8A FE 

P 0108 80 6E 



406 
407 
408 
409 
410 
411 
412 
413 
414 
415 
416 
417 
418 
419 
420 
421 
422 
423 
424 
425 
426 
427 
428 
429 
430 
431 
432 
433 
434 
435 
436 
437 
438 
439 
440 
441 
442 
443 
444 
445 
446 
447 
448 
449 
450 
451 
452 
453 
454 
455 
456 
457 
458 
459 
460 
461 
462 
463 
464 
465 
466 
467 
468 
469 



GLOBAL 

ser input PROCEDURE 

! «ft7ft «»»»» »»«»««»»»«»»» UK »«««»»»««»»ftif»«»«»»ii»ii«»it ft 11 »» 

Interrupt service - Serial Input 

Purpose = To service IRQ3 by inputting current 

character into next available position 
in circular buffer. 

Input = None. 

Output = New character inserted in buffer. 
SER__stat , SER_put updated. 

Note r 1 . If even parity enabled, the software 
replaces the eigth data bit with a 
parity error flag. 

2. If BREAK detection is enabled, and 
the received character is null, 

the serial input line is monitored^ to 
detect a potential BREAK condition. 
BREAK is defined as a zero start bit 
followed by 8 zero data bits and a 
zero stop bit. 

3. If 'buffer full' on entry, 'input 
buffer overflow' is flagged. 

4. If input echo is on, the character is 
immediately sent to the output serial 
channel . 

5. IMR is modified to allow selected 
nested interrupts (see ser__init) . 

ftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftftfti 

ENTRY 



Id 


SER_tmp1,%03 !read stop bit level! 


push 


imr !save entry imr! 


and 


imr,SER imr fallow nesting! 


ei 


■"" 


push 


rp !save user's! 


srp 


#RAM_STARTr 


Id 


rSERchar,SIO ! capture input! 


tm 


rSERcfg,#be !break detect enabled?! 


jr 


z,ser 30 fnope.! 


clr 


rSERtmp2 


tm 


rSERcfg,#op !odd parity enabled?! 


jr 


z,ser 23 !no.! 


Id 


rSERtmp2,#%80 


cp 


rSERchar,rSERtmp2 !8 received bits = 0? 


jr 


ne,ser 30 !no! 


tm 


rSERtmp1,#1 !test stop bit! 


jr 


nz,ser_30 !not BREAK! 



ser 23: 



!is BREAK. Wait for marking! 

or rSERflg,y/bd 

ser_24: tm %03,#1 

jr z,ser 24 

!wait 1 char time to Tlush receive shift register! 

push SERhtime 

push SERltime !save PREO x TO! 

in_loop: Id rSERtmp1,#53 

Ipl: djnz rSERtmp1,lp1 !delay 640 cycles! 

decw SERhtime 



!set BREAK flag! 
!marking yet?! 
!not yet! 
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P 010A EB 


F8 




470 
471 
472 




jr 


nz,ln_loop 


!delay ( 128x10xPRE0xT0) ! 

1 , 1 






! 2 ! 




P 010C 50 


6F 




473 




pop 


SERltime 






P 010E 50 


6E 




474 




pop 


SERhtlme 


!restore PREO x TO! 




P ,0110 56 


FA 


F7 


475 




and 


IRQ,//LNOT X08 


!clear Int req! 




P 0113 8B 


49 




476 
477 




Jr 


ser_i5 


!bye! 




P 0115 76 


EO 


01 


478 


ser 30: 


tm 


rSERflg,#bf 


!buffer full?! 




P 0118 EB 


4A 




479 




jr 


nz,ser 11 


! yes. overflow! 




P 011A 76 


E2 


01 


480 




tm 


rSERcfg,#ec 


!echo on?! 




P 011D 6B 


OA 




481 




jr 


z,ser 10 


!no1 




P 011F A9 


FO 




482 




Id 


SIOjr'SERchar 


!echo! 




P 0121 66 


FA 


10 


4.83 


ser 16: 


tcm 


IRQ,#X10 


!poll! 




P 012iJ EB 


FB 




484 




jr 


nz,ser 16 


!loop! 




P 0126 56 


FA 


EF 


485 




and 


IRQ,//LTTOT %^0 


!clear Irq bit! 




P 0129 76 


E2 


40 


486 


ser_iO: 


tm 


rSERcfg,//ep 


!even parity?! 




P 012C 6B 


14 




487 




jr 


z,ser 22 


!no parity! 










488 


jc^lculate pari 


Lty error flag! 






P 012E 8C 


07 




489 




Id 


rSERtrap1,#7 






P 0130 BO 


E9 




490 




clr 


rSERtmp2 


!count 1 's here! 




P 0132 CO 


EA 




491 


ser_20: 


rrc 


rSERchar 


!blt to carry! 




P 013^ 16 


E9 


00 


492 




adc 


rSERtmp2,#0 


!update 1 's count! 




P 0137 8A 


F9 




493 




djnz 


rSERtmp1,ser 20 


!loop till done! 




P 0139 56 


E9 


01 


494 




and 


rSERtmp2,//1 


!1's count even or odd?! 




P 013C B2 


A9 




495 




xor 


rSERchar, rSERtmp2 




P 013E CO 


EA 




496 




rrc 


rSERchar 


! parity error flag...! 




P Oli^O CO 


EA 




497 




rrc 


rSERchar 


! ...to bit 7! 




P 01M2 88 


E4 




498 


ser_22: 


Id 


rSERtmph,rSERbul 


rh 




p o^u^ 98 


E5 




499 




Id 


rSERtmpl,rSERbuj 


ri 




P 0146 02 


97 




500 




add 


rSERtmpl ,rSERput !next char address! 




P 01il8 8E 






501 




Inc 


rSERtmph 


!ln external memory?! 




P 01M9 8A 


IE 




502 




djnz 


rSERtraph,ser 12 


!yes.! 


% 


P 01i4B F3 


9A 




503 




Id 


§rSERtmpl ,rSrRchar ! store char In buf! 




P 014D 46 


EO 


02 


504 


ser 13: 


or 


rSERflg,#bne 


!buffer not empty! 




P 0150 7E 






505 




Inc 


rSERput 


!update put ptr! 




P 0151 A2 


76 




506 




cp 


rSERput,rSERlen 


! wrap-around?! 




P 0153 EB 


02 




507 




jr 


ne,ser 14 


!no! 




P 0155 BO 


E7 




508 




clr 


rSERput 


!set to start! 




P 0157 A2 


71 




509 


ser 14: 


cp 


rSERput,rSERget 


!lf equal, then full! 




P 0159 EB 


03 




510 




jr 


ne,ser 15 






P 015B 46. 


EO 


01 


511 




or 


rSERflg,#bf 






P 015E 50 


FD 




512 


ser 15: 


pop 


rP 


! restore user's! 




P 0160 8F 






513 




dl 








P 0161 50 


FB 




514 




pop 


Imr 


!restore entry Imr! 




P 0163 BF 






515 
516 


\ 


Iret 








P 0164 46 


EO 


04 


517 


ser_11: 


or 


rSERflg,//bo 


!buffer overflow! 




P 0167 8B 


F5 




518 
519 




jr 


ser_^15 






P 0169 16 


E8 


00 


520 


ser 12: 


adc 


rSERtmph, #0 






P 016C 92 


A8 




521 




Ide 


@rrSERtmp, rSERchar ! store In buf! 




P 016E 8B 


DD 




522 




jr 


ser 13 






P 0170 






523 


END 


ser Inp 


)Ut 







266 











525 


GLOBAL 




!for PART I! 


P 0170 








526 


ser get 


PROCEDURE 










527 


1 »«7««»ft»»ft »»«»»»«««»»» ft »»»»»»»«»»»»»««»»» »«»»«»»«««»» 










528 


Purpose = 


To return one serial input character. 










529 
















530 


Input 


= 


None. 










531 
















532 


Output 


- 


Carry FLAG = 1 if BREAK detected or 










533 






serial not enabled 










53M 






or buffer overflow 










535 






r otherwise 










536 






TEMP_1 s character 










537 
















538 


Note = 




This routine will not return control 










539 






until a character is available in the 










540 






input buffer or an error is detected. 










541 


»»»»»»»ftftftft«ftft«»»»ftft»ftftft»»ft»«ftft»««ftft«ftftft»«»ftftftftftftft»ftftt 










542 


ENTRY 






P 0170 


70 


FD 




543 




push 


rp !save caller 's rp! 


P 0172 


31 


70 




544 




srp 


#RAM STARTr ! point to subr . RAM! 


P 017U 


DF 






545 




scf 


!in case error! 


P 0175 


76 


EO 


8C 


546 
547 
548 
549 


ser__g1 : 


tm 


rSERflg,#sd LOR bd LOR bo 

! serial disabled or 
BREAK detected or 
buffer overflow?! 


P 0178 


EB 


24 




550 




jr 


nz,ser g6 !yes.! 


P 017A 


76 


EO 


02 


551 




tm 


rSERflg,//bne !buffer not empty?! 


P 017D 


6B 


F6 




552 




jr 


z,ser g1 !empty. wait! 


P 017F 


D8 


E5 




553 




Id 


rTEMP""ll,rSERbufl 


P 0181 


C8 


E4 




55^ 




Id . 


rTEMP"1h,rSERbufh 


P 0183 


8F 






555 




di 


! prevent IRQ3 conflict! 


P 018U 


02 


D1 




556 




add 


rTEMP 11,rSERget !next char address! 


P 0186 


CE 






557 




inc 


rTEMP 1h ! input buffer in...! 


P 0187 


CA 


18 




558 
559 




djnz 


rTEMP 1h,ser g3 !... external memory! 
! . . .register memory! 


P 0189 


E3 


CD 




560 




Id 


rTEMP 1 ,@rTEMP 11 !get char! 


P 018B 


56 


EO 


FE 


561 


ser g4: 


and 


rSERfTg,#LNOT bf ! buffer not full! 


P 018E 


IE 






562 




inc 


rSERget !update get pointer! 


P 018F 


A2 


16 




563 




cp 


rSERget,rSERlen ! wrap-around?! 


P 0191 


EB 


02 




564 




jr 


ne,ser__g2 !no.! 


P 0193 


BO 


El 




565 




clr 


rSERget !yes. set to start! 


P 0195 


A2 


17 




566 


ser g2: 


cp 


rSERget,rSERput !buffer empty if get...! 


P 0197 


EB 


03 




567 




jr 


ne,ser g5 ! . . .and put =! 


P .0199 


56 


EO 


FD 


568 




and 


rSERflg,#LNOT bne !buffer empty now! 


P 019C 


CF 






569 


ser g5: 


rcf 


!set good return! 


P 019D 


9F 






570 




ei 


!re-enable interrupts! 


P 019E 


50 


FD 




571 


ser_g6: 


pop 


rp !restore caller's rp! 


P 01A0 


AF 






572 
573 




ret 




P 01A1 


16 


EC 


00 


574 


ser_g3: 


adc 


rTEMP 1h,#0 !rrTEMP .1 has char addr! 


P 01A4 


82 


CC 




575 




Ide 


rTEMP 1,§rrTEMP_1 !get char! 


P 01A6 


8B 


E3 




576 




jr 


ser_g4 ! clean up! 


P 01A8 








577 


END 


ser_get 
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579 GLOBAL 
p 01A8 580 ser break PROCEDURE 

531 I »»?«»»««»« «»»ji» »»««»»«» »»»«»»«»»]( »«»»»»»«««» »«ii »»»»»» 

582 break transmission 

583 

584 Purpose r To transmit BREAK on the serial line. 

585 

586 Input = ' RR14 = break length 

587 

588 Output s None. 

589 

590 Note s BREAK is defined as: 

591 serial out (P37) = for 

592 2 X 2B cycles/loop x RR14 loops 



593 

59M XTAL 

595 

596 RR14 should yield at least 1 bit time 

597 so that the last 'clr SIO' will 

598 have been preceded by at least 1 bit 

599 time of spacing. Therefore, RR14 should 

600 be greater than or equal to 
601 

602 4 X 16 X PREO x TO 



603 

604 28 

505 »»»»»»««»»»»»»»»»«»»»«»«»»»*«**«»*»******************! 

606 E,NTRY 

607 ser_b1: 

P 01A8 80 FO 608 clr SIC 

P 01AA 80 EE 609 decw RR1M 

P 01AC EB FA 610 jr nz, ser b1 

611 ! wait for last null to"l)e fully transmitted! 
P 01AE 8D 0238' 612 jp ser_o1 
p 01B1 613 END ser_break 

615 GLOBAL 

P 01B1 616 ser flush PROCEDURE 

617 ! **'^*»*«***»*«««»»*»»»««««* «»»»»»»«»»»»»»»»»»«)(» »»««»» 

618 input flush 
619 

620 Purpose s To flush (clear) the serial input 

621 buffer of characters. 
622 

623 Input = None 

624 

625 Output = Empty input buffer. 

626 

627 Note = This routine might be useful to clear 

628 all past input after a BREAK has been 

629 detected on the line. 

631 ENTRY 

fdisable interrupts! 
!(to avoid collision with 
serial input)! 
SER_get ! buffer start! 
SER_put !s buffer end! 
80 637 and SER_flg,//%80 ! clear status! 

!re-.enable interrupts! 



P 01B1 8F 




P 01B2 BO 


71 


P 01B4 BO 


77 


P 01B6 56 


70 


P 01B9 9F 




P 01BA AF 




P 01BB 





632 


di 


633 




634 




635 


clr s: 


636 


clr S 


637 


and S 


638 


ei 


639 


ret 


640 END 


ser flush 
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P 01BB 



P 01BB BO 7E 



01BD DF 
01BE 76 
01C1 EB 
01C3 70 
01C5 D6 
01C8 D6 
01CB 7B 
01CD A6 
01D0 EB 
01D2 56 
01D5 A6 
01D8 EB 
01DA 00 
01DC 76 
01DF 6B 
01E1 E6 
01EM D6 
01E7 8B 
01E9 DA 
01EB 50 
01ED 24 
01F0 D8 
01F2 CF 
01F3 AF 
01FH 



70 80 

30 

ED 

0000* 

020B' 

IE 

7E 00 

17 

7C 

7C 

OF 

ED 

72 

OA 

7C 

020B' 

02 

DA 

7C 

ED ' 7C 

7C 



7F 
OD 



OU 



OA 



642 CONSTANT 

643 wli_len 

644 GLOBAL 

645 ser wlin 
5145 {»«T»ft»1l«»»l(ft« 

647 write line 

648 

649 Purpose = 

650 

651 

652 

653 

654 Input = 

655 

656 

657 

658 Output = 

659 

660 

661 

662 

663 

664 Note = 

665 

666 

667 

668 



669 ENTRY 

670 clr 
671 

672 write: scf 

673 tm 

674 jr 

675 push 

676 wli_4: call 

677 call 

678 jr 

679 cp 

680 jr 

681 and 

682 cp 

683 jr 

684 dec 

685 tm 

686 jr 

687 Id 

688 call 

689 jr 

690 wli_5: djnz 

691 wli_2: pop 

692 sub 

693 Id 

694 rcf 

695 wli_1: ret v 

696 END ser wlih 



:= R13 

PROCEDURE 



To output a character string to serial 
line, ending with either a ♦carriage 
return' character or the maximum length 
specified. 

RR14 = address of source buffer 

(in reg/ext memory) 
R13 = length 

RR14 = updated 

Carry Flag = 1 if serial not enabled, 

= if no error . 
R13 = # bytes output (not including 
auto line feed) 

If auto line feed is enabled, a 
line feed character will be output 
following each carriage return 
(ser wlin only) . 



TEMP 3 



SER_flg,#sd 

nz,wli__1 

wli_len 

get src 

ser'^output 

c,wTi 2 

TEHP_1,#0 

nz,wli_5 ^ 

TEMP_1,//%7F 

TEMP 1,#%0D 

n z , wTi_5 

wli_len 

SER_cfg,//al 

z,wli 2 

TEMP__T,#^OA 

ser output 

wl i~2 

wli len.wli 4 

TEM"P__1 

TEMP 1,wli len 

wli Ten,TEHP_1 



!flag => write line! 

! in case error! 
iserial disabled?! 
!yes. error! 



!write the character! 
! serial disabled! 
!write line?! 
!no, absolute.! 
!mask off parity! 
!line done?! 
!yes.! 

!auto line feed?! 
!disabled! 
!output line feed! 



!loop! 

!original length! 

!return output count! 
!no error! 
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p 


01Fi| E6 


7E 


p 


01F7 8B 


C4 


p 


01F9 





698 GLOBAL 

P 0^F^ 699 ser wabs PROCEDURE 

700 !»«'i'»»»»»»»)i»«ii«ii»ft»»»ii»»»»«ft)i««»««ft««»»»»»«)iii»f»»»»ii« 

701 write absolute 
702 

703 Purpose = To output a character string to serial 

704 line for the length specified. (Output 

705 is not terminated with the output of 

706 a 'carriage return'). 
707 

708 Note = All other details are as for 'ser wlin'. 

709 «»»«»»»«»»»»»» »»»»»»»»«»»»»)i» »»»»»»»»»»»«»» v******!****! 

710 ENTRY 
01 711 Id TEMP_3,#1 

712 jr write 

713 END ser_wabs 

P 01F9 . 715 ser wbyt PROCEDURE 

717 write byte 

718 . 

719 Purpose r To output a given character to the 

720 serial line. If the character is a 

721 carriage return and auto line feed 

722 is enabled, a line feed will be output 

723 as well. 
724 

725 Input = R12 = character to output 
726 

727 Note s Equivalent to ser wlin with length = 1. 

728 )(*»«»«)()(»»«»»»»«»»»«»»»»»»«»»»«»»▼»»»»»»*»»»*»»«»»«««! 

729 ENTRY 

P 01F9 C9 7C 730 Id TEMP_1,R12 

P 01FB D6 020B' 731 call ser_output !output it! 

P 01FE 76 72 04 732 tin SER cfg,#al lauto line feed?! 

P 0201 6B 3E 733 jr z,ser 05 !not enabled! 

P 0203 A6 EC OD 73^ cp R12,#T0D !char = car. ret?! 

P 0206 EB 39 735 jr nz,ser 05 .!nope! 

P 0208 E6 7C OA 736 Id TEMP 17#$0A !output line feed! 

737 !fall into ser output! 
P 020B 738 END ser wbyt 
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740 


GLOBAL 




!for PART I! 




P 020B 








741 


ser output 


PROCEDURE 












742 


{»»¥ii«»»»ft»«ii»»»«ii»«)ift«««ft«»»«»«»»«»«»»)(ii«»«i(»««»»»»«« 










743 


Purpose = 


To output one ( 


character to the serial 










744 






line. 












745 


















746 


Input 


= 


TEMP_1 = character 










747 


















748 


Output 


= 


Carry FLAG = 1 


if serial disabled 










749 






= 


otherwise. 










750 


















751 


Note = 




1 . If even par: 


Lty is enabled, the eigth 










752 






data bit is modified prior to character 










753 






output to SIO. 












754 








; 










755 






2. IRQ4 is polled to wait for completion 










756 






of character transmission before control 










757 






returns to the 


calling program. 










758 


»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»»! 










759 


ENTRY 








P 020B 


DF 






760 




scf 




! in case error! 


P 020C 


76 


70 


80 


761 




tm 


SER flg,//sd 


iserial disabled?! 


P 020F 


EB 


30 




762 




jr 


nz,ser 05 


!yes. error! 


P 0211 


76 


72 


40 


763 




tm 


SER cfg,//ep 


!even parity enabled?! 


P 021U 


6B 


IF 




764 




jr 


z.ser o2 


!no. just^ output! 










765 


'calculate parity! "" 




P 0216 


70 


7E 




766 




push 


TEMP 3 




P 02ie 


E6 


7E 


07 


767 




Id 


TEMP""3,#7 




P 021B 


BO 


7D 




768 




clr 


TEMP~2 




P 021D 


CO 


7C 




769 


ser 04: 


rrc 


TEMP 1 


!character bit to carry! 


P 021F 


16 


7D 


00 


770 


' 


adc 


TEMP'"2,#0 


!count 1's! 


P 0222 


00 


7E 




771 




dec 


TEMp-3 




P 022U 


EB 


F7 




772 




jr 


nz,ser 04 


!next bit! 


P 0226 


56 


7D 


01 


773 




and 


TEMP 2, #01 


!1's count odd/even! 


P 0229 


56 


7C 


FE 


774 




and 


TEMP"1,#%FE 




P 022C 


44 


7D 


7C 


775 




or 


TEMP 1,TEMP 2 


!parity bit in DO! 


P 022F 


CO 


7C 




776 




rrc 


TEMp-1 




P 0231 


CO 


7C 




777 




rrc 


TEMP'I 


! parity bit in D7! 


P 0233 


50 


7E 




778 




pop 


TEMP 3 




P 0235 


E4 


7C 


FO 


779 


ser o2: 


Id 


SIO, TEMP 1 


!output character! 


P 0238 


66 


FA 


10 


780 


ser o1 : 


tcm 


IRQ,//%10 


!check IRQ4! 


P 023B 


EB 


FB 




781 




jr 


nz,ser o1 


!wait for complete! 


P 023D 


56 


FA 


EF 


782 




and 


irq,#%i:f 


!clear IRQ4! 


P 0240 


CF 






783 




rcf 




!all ok! 


P 0241 


AF 






784 


ser 05: 


ret 






P 0242 








785 
787 


END 
GLOBAL 


ser_ 


output 




P 0242 








788 


ser disable 


PROCEDURE 












789 


t »«¥»»»»»««» »ii»ii« »»»»»» »»»«»ii»»»»»»)it»»»»»ii»ii«ft»»»»««)i 










790 


disable 
















791 


















792 


Purpose = 


To disable ser: 


Lai I/O operations. 










793 


















794 


Input 


= 


None. 












795 


















796 


Output 


- 


Serial I/O diss 


abled. 










797 


««»»»)i»«)i»»»»»««««ii»»»««)i«««»«» »»»»«»«»»»« »»»»»«««»«»! 










798 


ENTRY 








P 0242 


8F 






799 




di 


! avoid 


IRQ3 conflict! 


P 024 3 


46 


70 


80 


800 




or 


SER flg,#sd 












801 






!set serial disabled! 


P 0246 


56 


F1 


FC 


802 




and 


TMR,#$FC 












803 






!disable TO! 


P 0249 


56 


FB 


E7 


804 




and 


IMR,#%E7 












805 






!disable IRQ3,4! 


P 02 4C 


56 


7F 


BF 


806 
807 




and 


P3M save,#$BF 
!P30/7 


normal i/o pins! 


P 02 4 F 


E4 


7F 


F7 


808 




Id 


P3M,P3M_save 




P O.^S2 


9F 






809 




ei 


!re-enable interrupts! 


r O.^S^ 


AF 






810 




ret 






p or<n 








811 


END 


ser 


disable 





271 



Timer/Counter Routines , 

840 

842 
843 
844 
P 0254 845 

846 
847 
848 
849 
850 
851 
852 
853 
854 

855 
856 
857 
858 
859 
860 
861 
862 
863 
864 
865 
866 
867 
868 
869 
870 
871 
872 
873 
87'4 
875 
876 
877 
878 
879 
880 
881 
882 
883 
884 
885 
886 
887 
888 
889 
890 
891 
P 0254 DC 6C 892 
P 0256 C3 DE 893 
P 0258 C3 DE 894 
P 025A E6 7B 6C 895 
P 025D 8D 02B2» 896 
P 0260 897 



CONSTANT 

TMP := R13 

PTR := RR14 

PTRh := R14 
GLOBAL 
tod i PROCEDURE 

time of day : initialize 

Purpose = To initialize TO or T1 to function as 
a time of day clock. 

Input = RR14 r address of parameter list in 
program memory: 
1 byte = IMR mask for nestable 

interrupts 
1 byte = // of clock ticks per second 
1 byte = counter # : = %F4 => TO 
= %F2 => T1 
1 byte r Counter value 
1 byte = Prescaler value (unshifted) 

TOD_hr, TOD_min, TOD_sec , TOD_tt 
initialized to the starting time of 
hours, minutes, seconds, and ticks 
respectively. 

Output = Selected timer is loaded and 

enabled; corresponding interrupt 

is enabled. 

R13, R14, R15 modified. 

Note = The cntr and prescaler values provided 
are those values which will generate an 
interrupt (tick) the designated # of 
times per second. 

For example: 

for XTAL = 8 MHZ, cntr = 250 and 
prescaler = 40 yield a .01 sec interval; 
the 2nd byte of the parameter list 
should = 100 . 

For TO the instruction at %080C or 
for T1 the instruction at %080F must 
result in a jump to the jump table entry 
for ♦tod*. 

The parameter list is not referenced 
following initialization. 

ENTRY 

Id TMP, //TOD imr 

Idci @TMP,§PT'R !imr mask! 

Idci @TMP,§PTR ! ticks/second! 

Id TEMP_4,#T0D_imr 

jp pre ctr !ctr & prescaler! 
END tod i ~ 
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P 0260 



899 GLOBAL 

900 tod PROCEDURE 

902 Interrupt service - time of day 

903 

90U Purpose s To update the time of day clock. 

905 ««»«»»»»»»«»»«««»« »«»««»»««»»»»«»»»««»»» »*«»»»«»«»««»! 

906 ENTRY 



P 0260 


70 


FB 




907 


push 


imr 


Isave entry, imr! 


P 0262 


54 


6C 


FB 


908 


and 


imr ,TOD_imr 


! allow nested interrupts 


P 0265 


9F 






909 


ei 




! enable interrupts! 


P 0266 


70 


FD 




910 


push 


rp 


!save rp! 


P 0268 


31 


60 




911 


srp 


#RAM TMRr 


! point to our set! 


P 026A 


8E 






912 


inc 


rTOD^t 


! ticks/second! 


P 026B 


A2 


8D 




913 


cp 


rTODtt,rTODtic 


I second complete?! 


P 026D 


EB 


13 




914 


jr 


ne,tod ex 


!nope.! 


P 026F 


BO 


E8 




915 


clr 


rTODtt" 




P 0271 


9E 






916 


inc 


rTODsec 


! seconds! 


P 0272 


A6 


E9 


3C 


917 


cp 


rTODsec ,#60 


!minute complete?! 


P 0275 


EB 


OB 




918 


jr 


ne,tod ex 


!nope.! 


P 0277 


BO 


E9 




919 


clr 


rTODsec 




P 0279 


AE 






920 


inc 


rTODmin 


!minutes! 


P 027A 


A6 


EA 


3C 


921 


cp 


rT0Dmin,#60 


!hour complete?! 


P 027D 


EB 


03 




922 


jr 


ne.tod ex 


!nope.! 


P 027F 


BO 


EA 




923 


clr 


rTODmin 




P 0281 


BE 






924 
925 


inc 


rTODhr 


! hours! 


P 0282 


50 


FD 




926 tod ex: 


pop 


rp 


!restore rp! 


P 0284 


8F 






927 


di 




!disable interrupts! 


P 0285 


50 


FB 




928 


pop 


imr 


!restore entry imr! 


P 0287 


BF 






929 


iret 






P 0288 








930 END 


tod 
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P 0288 



0288 DC 
028A C3 
028C C3 
028E C3 
0290 80 
0292 80 
029M 56 
0297 56 
029A EH 
029D E6 
02A0 8D 
02A3 



P 02A3 



P 02AC F5 
P 02AF BF 
P 02B0 



65 
DE 
DE 
DE 
EE 
EE 
F1 
7F 
7F 
7B 
02B2 



3F 
DF 
F7 
01 



P 02A3 Bi| 65 67 
P 02A6 BM 67 65 
P 02A9 B4 65 67 



67 66 



I «»»»«»»»««»»» »»»ii»»«»«iiii»»»«»»«ii»»iiii«ii«»»ii»»ft»]i»ii«»»)i 



Purpose = 



Input = 



932 GLOBAL 

933 pulse_i PROCEDURE 
934 
935 
936 
937 
938 
939 
9M0 
941 
942 
943 
944 
945 
946 
947 
948 
949 
950 
951 
952 
953 
954 
955 
956 
957 
958 



Output = 



Note 



To initialize one of the timers 
to generate a variable frequency/ 
variable pulse width output. 

RR14 = address of parameter list in 
program memory: 
1 byte s cntr value for low interval 
1 byte = counter // : = %F4 => TO 
= %F2 => T1 
1 byte = cntr value for high interval 
1 byte = prescaler (unshifted) 

Selected timer is loaded and 
enabled; corresponding interrupt 
is enabled. P36 is enabled as Tout. 
R13, R114, R15 modified. 

The parameter list is not referenced 
following initialization. 



The value of Prescaler x Counter 
must be > 26 (=%1A) for proper 
operation . 

959 ENTRY 

960 LD TMP,#PLS__2 
@TMP,§PTR 
@TMP,§PTR 
@TMP,§PTR 
PTR 
PTR 

TMR,//%3F 
P3M save,#%DF 
P3MTP3M_save 
TEMP__4,#^1 
pre ctr 



961 
962 
963 
964 
965 
966 
967 
968 
969 
970 
971 
972 
973 

974 GLOBAL 

975 pulse 
976 



END 



LD 

Idci 

Idci 

Idci 

decw 

decw 

and 

and 

Id 

Id 

JP 
pulse i 



!low interval cntr! 

ftimer addr! 

!high interval cntr! 

!back to flag! 

!will be modifying TMR! 

!P36 = Tout! 

!flag for pre ctr! 
! set up timerT 



PROCEDURE 

Purpose = To modify the counter load value . 

to continue the pulse output generation. 



977 
978 
979 
930 »«»««§»«»»«»««» »»»»»»«ft«i(«»»»»»«»»«»«»»«»»]i««««*»«»ft» I 

981 ENTRY 

982 !exchange values! \ 
xor PLS__1 , PLS_2 
xor PLS 2,PLS_1 
xor PLS_1,PLS__2 

!exchange complete! 

Id @PLS_tmr,PLS_1 
iret 



983 
984 
985 
986 
987 
988 
989 END 



!load new value! 



pulse 
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P 02B0 



P 02B0 BO 7B 
P 02B2 



991 

992 

993 

99M 

995 

996 

997 

998 

999 

1000 

1001 

1002 

1003 

1004 

1005 

1006 

1007 

1008 

1009 

1010 

1011 

1012 

1013 

1014 

1015 

1016 

1017 

1018 

1019 

1020 

1021 

1022 

1023 

1024 



GLOBAL 

delay PROCEDURE 

]»««««»»ii»«»f»»»«»»»«»»«»ii]iii«»««««»»»«»«»«i»»««»»«»«««» 
Purpose r To generate an interrupt after a 
designated amount ot time. 

Input = RR14 = address of parameter list in 
program memory: 
1 byte = counter # : = %F4 => TO 
= %F2 => Tl 
1 byte = Counter value 
1 byte = Prescaler value and count mode 
(to be loaded as is into 
PREO or PRm). 

Output = Selected timer is loaded and 

enabled; corresponding interrupt 

is enabled. 

R13, R14, R15 modified. 

Note = This routine will initialize the timer 
for single-pass or continuous mode 
as determined by bit of byte 3 in 
the parameter list. 

The caller is responsible for provid- 
ing the interrupt service routine. 

The parameter list is not referenced 
following initialization. 

ENTRY 

clr TEMP__4 
!fall into pre_ctrf 
END delay 
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P 02B2 



02B2 C2 
02BU AO 
02B6 E6 
02B9 E6 
02BC A6 
02BF 6B 
02C1 E6 
02CM E6 
02C7 C3 
02C9 C2 
02CB A6 
02CE 6B 
02D0 DF 
02D1 10 
02D3 DF 
02Di| 10 
02D6 A6 
02D9 EB 
02DB 60 
02DD 5^ 
02E0 60 
02E2 56 
02E5 F3 
02E7 U4 
02EA 8F 

02EB nn 

02EE 9F 
02EF AF 
02F0 



DE 

EE 

7D 8C 

7E 20 

ED F2 

06 

7D M3 

7E 10 

DE 

EE 

7B 00 

12 

EE 

EE 

7B 6C 

OA 

7E 

7E 6C 

7E 

7D OF 

DE 

7D F1 

7E FB 



1026 
1027 
1028 
1029 
1030 
1031 
1032 
1033 
1034 
1035 
1036 
1037 
1038 
1039 
10M0 
10M1 
1042 
1043 
104M 
1045 
1046 
1047 
1048 
10^9 
1050 
1051 
1052 
1053 
1054 
1055 
1056 
1057 
•1058 
1059 
1060 
1061 
1062 
1063 
1064 

1065 
1066 
1067 



INTERNAL 

pre ctr PROCEDURE 

Purpose s To get counter and prescaler values 

from parameter list and modify control 
registers appropriately. 



pre 1 : 



Input s 

ENTRY 

Idc 

incw 

Id 

Id 

cp 

jr 

Id 

Id 

Idci 

Idc 

cp 

jr 

scf 

rlc 

scf 

rlc 

cp 

jr 

com 

and 

com 

and 

Id 

or 

di 

or 

ei 

ret 

pre 



TEMP_4 = => for 'delay' 
= 1 => for 'pulse' 
= TOD imr => for 'tod' 



pre_2: 
pre_3: 



END 



!T0 or T1! 

I for TMR! 
!for IMR! 

!is for T1! 

!for TMR! 

!for IMR! 

! init counter! 

!prescaler ! 

! shift prescaler?! 

!no! 

! internal clock! 



TMP,§PTR 

PTR 

TEMP 2,#%8C 

TEMP~3,#%20 

TMP,?T1 

eq,pre_1 

TEMP 2,#%43 

TEMP~3,#%10 

@TMP,@PTR 

PTRh,§PTR 

TEMP_4,#0 

eq,pre_2 

PTRh 

icontinuous mode! 
PTRh 

TEMP_4,#T0D_imr 
ne,pre_3 ! for 'pulse'! 
TEMP 3 

TOD_Tmr ,TEMP_3 'insure no self-nesting! 
TEMP 3 

TEMP 2tH0F !no Tout mode mod! 

@TMP,PTRh !init prescaler! 
TMR, TEMP 2 !init tmr mode! 



imr,TEMP_3 



!enable interrupt! 



ctr 



END PART II 



errors 
Assembly complete 
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Microcomputer Units 



^ZilCG 
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May 1981 



INTRODUCTION 

The microcomputer industry has recently developed 
single-chip microcomputers that incorporate on one 
chip functions previously performed by periph- 
erals. These microcomputer units (MCUs) are aimed 



at markets requiring a dedicated computer. This 
report describes and compares the most powerful 
MCUs in today's market: the Zilog Z8611, the 
Intel 8051, and the Motorola MC6801 . Table 1 
lists facts that should be considered when com- 
paring these MCUs. 



Table 1. MCU Comparison 



FEATURES 


Zilog 
Z8611 


Intel 
8051 


Motorola 
MC6801 


On-Chip ROM 


4Kx8 


4Kx8 


2Kx8 


General-Purpose 
Registers 


124 


128 


128 


Special-Function 
Registers 

Status/Control 
I/O ports 


/ 

16 
4 


16 
4 


17 
4 


I/O 

Parallel lines 

Ports 

Handshake 


32 

Four 8-bit 
Hardware on 
three ports 


32 

Four 8-bit 

None 


29 

Three 8-bit, one 5-bit 
Hardware on 
one port 


Interrupts 

Source 

External source 
Vector 
Priority 

Maskable 


8 
4 
6 
48 Programmable 

orders 
6 


5 
2 
5 
2 Programmable 

orders 
5 


7 
2 
7 
Nonprogrammable 

6 


External 
Memory 


120K bytes 


124K bytes 


64K bytes 


Stack 

Stack pointer 
Internal stack 

External stack 


16-Bit 
Yes, uses 
8-bits 
Yes 


8-Bit 
Yes 

No 


16-Bit 
Yes 

Yes 
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Table 



(Continued) 





Zilog 


Intel 


Motorola 


FEATURES 


Z8611 


8051 


MC6801 


Counter/ 








Timers 








Counters 


Two 8-bit 


Two 16-bit 
or two 8-bit 


One 16 -bit 


Prescalers 


Two 6-bit 


No prescale 

with 16-bits; 
5-bit prescale 

with 8-bits 


None 


Addressing 








Modes 








Register 


Yes 


Yes 


No 


Indirect Register 


Yes 


Yes 


No 


Indexed 


Yes 


Yes 


Yes 


Direct 


Yes 


Yes 


Yes 


Relative 


Yes 


Yes 


Yes 


Immediate 


Yes 


Yes 


Yes 


Implied 


Yes 


Yes 


Yes 


Index 








Registers 


124, Any 


1, Uses the 


1, Uses 




general- 


accumulator 


16-bit index 




purpose 


for 8-bit 


register 




register 


offset 




Serial 








Communication 








Interface 








Full duplex 








UART 


Yes 


Yes 


Yes 


Interrupts 








for transmit 








and receive 


One for each 


One for both 


One for bdth 


Registers 








Double buffer 


Receiver 


Receiver 


Transmitter/Receiver 


Serial Data Rate 


62.5K b/s 


187. 5K b/s 


62. 5K b/s 




®8 MHz 
93. 5K b/s 
mi MHz 


@12 MHz 


©4 MHz 


Speed 








Instruction 








execution average 


2.2 Usee 

1.5 Usee (i12 MHz 


1.5 Usee 


3.9 Usee 


Longest 








instruction 


4.25 Usee 

2.8 Usee i12 MHz 


4 Usee 


10 Usee 


Clock Frequency 


8 and 12 MHz 


12 MHz 


4 MHz 


Power Down 


Saves first 


Saves first 


Saves first 


Mode 


124 registers 


128 registers 


64 registers 


Context 


Saves PC 


Saves PC; 


Saves PC, PSW, 


Switching 


and flags 


programmer 


accumulators. 






must save all 


and Index 






registers 


register 
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Table 1. HCU ComDarison 
(Continued) 



FEATURES 


Zilog 
Z8611 


Intel 
8051 


Motorola 
MC6801 


Development 


40- Pin 

Protopack (8613) 
64- Pin (8612) 
40-Pin ROMless 

(Z8681 ) 


40- Pin (8751) 


40- Pin (68701) 


Eprom 
Availability 


4K bytes (2732) 
2K bytes (2716) 

Now 


4K bytes 
TBA 


2K bytes 
Now 



ARCHITECTURAL OVERVIEW 

This section examines three chips: the on-chip 
functions and data areas manipulated by the Zilog, 
Intel and Motorola MCUs. The three chips have 
somewhat similar architectures. There are,, how- 
ever, fundamental differences in design criteria. 
The 8051 and the MC6801 were designed to maintain 
compatability with older products, whereas the 
Z8611 design was fr6e from such restrictions and 
could experiment with new ideas. Because of this, 
the accumulator architectures of the MC6801 and 
the 8051 are not as flexible as that of the Z8611, 
which allows any register to be used as an accumu- 
lator. 



Memory Spaces 

The Z8611 CPU manipulates data in four memory 
spaces: 

m 60K bytes of external data memory 

• 60K bytes of external program memory 

• 4K bytes of internal program memory (ROM) 

• 144-byte register file 

The 8051 CPU manipulates data in four memory 
spaces: 

• 64K bytes of external data memory 

• 60K bytes of external program memory 

• 4K bytes of internal program memory 

• 148-byte register file 

The MC6801 manipulates data in three memory 
spaces: 

• 62K bytes, of external memory 

• 2K bytes of internal program memory 

• 149-byte register file 



required with the MC6801 that is not necessary 
with the Z8611 or the 8051. 



On Chip RAM. All three chips use internal RAM as 
registers. These registers are divided into two 
catagories: general-purpose registers and special 
function registers (SFRs). 

The 124 general-purpose registers in the Z8611 are 
divided into eight groups of 16 registers each. 
In the first group, the lowest four registers are 
the I/O port registers. The other registers are 
general purpose and can be accessed with an 8-bit 
address or a short 4-bit address. Using the 4-bit 
address saves bytes and execution time. Four-bit 
short addresses are discussed later. The general- 
purpose registers can be used as accumulators, ad- 
dress pointers, or Index registers. 



The 128 general-purpose registers in the 8051 are 
grouped into two sets. The lower 32 bytes are 
allocated as four 8-register banks, and the upper 
registers are used for the stack or for general 
purpose. The registers cannot be used for index- 
ing or as address pointers. 



The MC6801 also has a 128-byte, general-purpose 
register bank, which can be used as a stack or as 
address pointers, but not as Index registers. 

As pointed out in Table 1, any of the Z8611 
general-purpose registers can be used for index- 
ing; the MC6801 and the 8051 cannot use registers 
this way. The Z8611 can use any register as an 
accumulator; the MC6801 and the 8051 have fixed 
accumulators. The use of registers as memory 
pointers is very valuable, and only the Z8611 can 
use its registers in this way. 



On-Chip ROM, All three chips have internal ROM 
for program memory. The Z8611 and the 8051 have 
4K bytes of internal ROM, and the MC6801 has 2K 
bytes. In some cases, external memory may be 



The number of general-purpose registers on each 
chip is comparable. However, because of its 
flexible design, the Z8611 clearly has a more 
powerful register architecture. 
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The Z8611 has 20 special function registers used 
for status, control, and I/O. These registers 
include: 

• Two registers for a 16-bit Stack Pointer (SPH, 
SPL) 

• One register used as Register Pointer for 
working registers (RP) 

• One register for the status flags (FLAGS) 

• One register for interrupt priority (IPR) 

• One register for interrupt mask (IMR) 

• One register for interrupt request (IRQ) 

• Three mode registers for the four ports (P01M, 
P2M, P3M) 

• Serial communications port used like a 
register (SIO) 

4 Two counter/timer registers (TO, T1) 

• One Timer Mode Register (TMR) 

• Two prescaler registers (PREO, PRE1) 

• Four I/O ports accessed as registers (PORTO, 
P0RT1, P0RT2, P0RT3) 

The 8051 also has 20 special function registers 
used for status, control, and I/O. They include: 

• One register for the Stack Pointer (SP) 

• Two accumulators (A,B) 

• One register for the Program Status Word 
(PSW) 

• Two registers for pointing to data memory 
(DPH, DPI) 

• Four registers that serve as two 16-bit 
counter/timers (THO, TH1 , TLO, TL1) 

• One mode register for the counter/timers 
(TMOD) 

• One control register for the counter/timers 
(ICON) 

• One register for interrupt enable (lEC) 

• One register for interrupt priority (IPC) 

• One register for serial communications buffer 
(SBUF) 

• One register for serial communications control 
(SCON) 

• Four registers used as the four I/O ports (PO, 
P1, P2, P3) 

The MC6801 has 21 special function registers used 
for status, control, and I/O. These include: 

• One register for RAM/EROM control 

• One serial receive register 

• One serial transmit register 

• One register for serial control and status 

• One serial rate and mode register 

• One register for status and control of port 3 

• One register for status and control of the 
timer 

• Two registers for the 16-bit timer 

• Two registers for 16-bit input capture used 
with timer 

• Two registers for 16-bit output compare used 
with timer 

• Four data direction registers associated with 
the four I/O ports 

• Four I/O ports 



The special function registers in the three chips 
seem comparable in number and function. However, 
upon closer examination, the SFRs of the MC6801 
prove less efficient than those of the Z8611. The 
MC6801 has five registers associated with the I/O 
ports, whereas the Z8611 uses only three registers 
for the same functions. The MC6801 uses four 
registers to perform the serial communication 
function, whereas the Z8611 uses only one register 
and part of another. 

The 8051 uses two registers for the accumulators; 
the Z8611 is not limited by this restriction. The 
8051 also uses two registers for the serial com- 
munication interface, whereas the Z8611 accom- 
plishes the same job with one register. Another 
two registers in the 8051 are used for data 
pointers; these are not necessary in the Z8611 
since any register can be used as an address 
pointer. 

The Z8611 uses registers more efficiently than 
either the MC6801 or the 8051. The registers saved 
by this optimal design are used to perform the 
functions needed for enhanced interrupt handling 
and for register pointing with short addresses. 
The Z8611 also supplies the extra register re- 
quired for the external stack. These features are 
not available on the 8051 or the MC6801. 

External Memory. All three chips can access 
external memory. The Z8611 and the 8051 can gen- 
erate signals used for selecting either program or 
data memory. The Data Memory strobe (the signal 
used for selecting data or program memory) gives 
the Z8611 access to 120K bytes of external memory 
(60K bytes in both program and data memory). The 
8051 can use 124K bytes of external memory (64K 
bytes of external data memory and 60K bytes of 
external program memory). The MC6801 can Access 
only 62K bytes of external memory and does not 
distinguish between program and data memory. Thus, 
the Z8611 and the 8051 are clearly able to access 
more external memory than the MC6801. 



On-Chip Peripheral Functions 

In addition to the CPU and memory spaces, all 
chips provide an interrupt system and extensive 
I/O facilities including I/O pins, parallel I/O 
ports, a bidirectional address/ data bus, and a 
serial port for I/O expansion. 



Interrupts. The Z5611 acknowledges interrupts 
from eight sources, four are external from pins 
IRQ0-IRQ3, and four are internal from serial-in, 
serial-out, and the two counter/timers. All 
interrupts are maskable, and a wide variety of 
priorities are realized with the Interrupt Mask 
Register and the Interrupt Priority Registers (see 
Table 1). All Z8611 interrupts are vectored, with 
six vectors located in the on-chip ROM. The 
vectors are fixed locations, two bytes long, that 
contain the memory address of the service routine. 
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The 8051 acknowledges interrupts from five 
sources: two external sources (from INTO and 
INT1) and three internal sources (one from each of 
the internal counters and one from the serial I/O 
port). All interrupts can be disabled individual- 
ly or globally. Each of the five sources can be 
assigned one of two priorities: high or low. All 
8051 interrupts are vectored. There are five 
fixed locations in memory, each eight bytes long, 
allocated to servicing the interrupt. 

The MC6801 has one external interrupt, one non- 
maskable interrupt, an internal interrupt request, 
and a software interrupt. The internal interrupts 
are caused by the serial I/O port, timer overflow, 
timer output compare, and timer input capture. 
The priority of each interrupt is preset and can- 
not be changed. The external interrupt can be 
masked in the Condition Code register. The MC6801 
vectors the interrupts to seven fixed addresses in 
ROM where the 16-bit address of the service 
routine is located. 

When an interrupt occurs in the 8051, only the 
Program Counter is saved; the user must save the 
flags, accumulator, and any registers that the 
interrupt service routine might affect. The 
MC6801 saves the Program Counter, acumulators. 
Index register, and the PSW; the user must save 
all registers that the interrupt service routine 
might affect. The Z8611 saves the Program Counter 
and the Flags register. To save the 16 working 
registers, only the Register Pointer register need 
be pushed onto the stack and another set of work- 
ing registers is used for the service routine. 
For more detail on working registers and interrupt 
context switching, see the Z8 Technical Manual 
(03-3047-02). 

With regard to interrupts, the Z8611 is clearly 
superior. The Z8611 requires only one command to 
save all the working registers, which greatly 
increases the efficiency of context switching. 



I/O Facilities. The Z8611 has 32 lines dedicated 
to I/O functions. These lines are grouped into 
four ports with eight lines per port. The ports 
can be configured individually under software 
contr.ol to provide input, output, multiplexed 
address/data lines, timing, and status. Input and 
output can be serial or parallel, with or without 
handshake. One port can be configured for serial 
transmission and four ports can be configured for 
parallel transmission. With parallel transmis- 
sion, ports 0, 1, and 2 can transmit data with the 
handshake provided by port 3. 

The 8051 also has 32 I/O lines grouped together 
into four ports of eight lines each. The ports can 
be configured under program control for parallel 
or serial I/O. The ports can also be configured 
for multiplexed address/data lines, timing, and 
status. Handshake is provided by user software. 

The MC6801 has 29 lines for I/O (three 8-bit ports 
and one 5-bit port). One port has two lines for 



handshake. The ports provide all the signals 
needed to control input and output either serially 
or in parallel, with or without multiplexed 
address/data lines. They can be used to interface 
with external memory. 

The main differences in. I/O facilities are the 
number of 8-bit ports and the hardware handshake. 
The Z8611 and the 8051 have four 8-bit ports, 
whereas the MC6801 has three 8-bit ports and an 
additional 5-bit port. The Z8611 has hardware 
handshake on three ports, the MC6801 has hardware 
handshake on only one port, and the 8051 has no 
hardware handshake. 



Counter/titnerSo The Z8611 has two 8-bit counters 
and two 6-bit programmable prescalers. One pre- 
scaler can be driven internally or externally; the 
other prescaler is driven internally only. Both 
timers can interrupt the CPU when counting is 
completed. The counters can operate in one of two 
modes: they can count down until interrupted, or 
they can count down, reload the initial value, and 
start counting down again (continuously). The 
counters for the Z8611 can be used for measuring 
time intervals and pulse widths, generating vari- 
able pulse widths, counting events, or generating 
periodic interrupts. 

The 8051 has two 16-bit counter /timers for measur- 
ing time intervals and pulse widths, generating 
pulse widths, counting events, and generating 
periodic interrupts. The counter/timers have 
several modes of operation. They can be used as 
8-bit counters or timers with two 5-bit program- 
mable prescalers. They can also be used as 16-bit 
counter/timers. Finally, they can be set as 8 -bit 
modulo-n counters with the reload value held in 
the high byte of the 16-bit register. An interrupt 
is generated when the counter/timer has completed 
counting. 

The MC6801 has one 16-bit counter which can be 
used for pulse-width measurement and generation. 
The counter/timer actually consists of three 
16-bit registers and an 8-bit control/status reg- 
ister. The timer has an input capture register, 
an output compare register, and a free-running 
counter. All three 16-bit registers can generate 
interrupts. 



Serial Communications Interface. The Z8611 has a 
programmable serial communication interface. The 
chip contains a UART for full-duplex, asynchron- 
ous, serial receiver/ transmitter operation. The 
bit rate is controlled by counter/timer and has 
a maximum bit rate of 93.500 b/s. An interrupt is 
generated when an assembled character is transfer- 
red to the receive buffer. The transmitted 
character generates a separate interrupt. The 
receive register is double-buffered. A hardware 
parity generator and detector are optional. 

The 8051 handles serial I/O using one of its 
parallel' ports. The 8051 bit rate is controlled 
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by counter/timer 1 and has a maximum bit rate of 
187,500 b/s. The 8051 generates one interrupt for 
both transmission and receipt. The receive reg- 
ister is double-buffered. 

The MC6801 contains a full-duplex, asynchronous, 
serial communication interface. The bit rate is 
controlled by a rate register and by the MCU's 
clock or an external clock. The maximum bit rate 
is 62,500 b/s. Both the transmit and the receive 
registers are double-buffered. The MC6801 gener- 
ates only one interrupt for both transmit and 
receive operations* No hardware parity generation 
or detection is available, although it does have 
automatic detection of framing errors and overrun 
conditions. 

The 8051 and the MC6801 generate only one inter- 
rupt for both transmit and receive, whereas the 
Z8611 has a separate interrupt for each. The 
ability to generate separate interrupts greatly 
enhances the use of serial communications, since 
separate service routines are often required for 
transmitting and receiving. 

Other differences between the Z8611, MC6801, and 
the 8051 occur in the hardware parity detector, 
the double-buffering of registers, framing error 
detectors and overrun conditions. The 8051 has a 
faster data rate than either the Z8611 or the 
MC6801. The MC6801 has the advantage of a hard- 
ware framing error detector and automatic detec- 
tion of overrun conditions. The MC6801 also has 
both its transmit and receive registers 
double-buffered. The Z8611 has a hardware parity 
detector. For detection of framing errors and 
overrun conditions, a simple, low-overhead soft- 
ware check is available that uses only two 
instructions. See Z8600 Software Framing Error 
Detection Application Brief (document #617-1881- 
0004). 



INSTRUCTION ARCHITECTURE 

The architecture of the Z8611 is designed specif- 
ically for microcomputer applications. This fact 
is manifest in the instruction composition. The 
arduous task of programming the MC6801 and the 
8051 starkly contrasts that of programming the 
Z8611. 



Addressing Modes 

The Z8611 and the 8051 both have six addressing 
modes: Register, Indirect Register, Indexed, 
Direct, Relative, and Immediate. The MC6801 has 
five addressing modes: Accumulator, Indexed, 
Direct, Relative, and Immediate. A quick compar- 
ison of these addressing modes reveals the versa- 
tility of the 28611 and the 8051. The addressing 
modes of the MC6801 have several restrictions, as 
shown in Table 1. While the 8051 has all the 
addressing modes of the Z8611, its use of them is 
restricted. The Z8611 allows many more combina- 



tions of addressing modes per instruction, because 
any of its registers can be used as an accumula- 
tor. For example, the" instructions to clear, 
complement, rotate, and swap nibbles are all 
accumulator oriented in the 8051 and operate on 
the accumulator only. These same commands in the 
Z8611 can use any register and access it either 
directly, y*ith register addressing, or with in- 
direct register addressing. 



Indexed Addressing. All three chips differ in 
their handling of indexing. The Z8611 can use any 
register fpr indexing. The 8051 can use only the 
accumulator as an Index register in conjunction 
with the data pointer or the Program Counter. The 
MC6801 has one 16-bit Index register. The address 
located in the second byte of an instruction is 
added to the lower byte of the Index register. 
The carry is added to the upper byte for the com- 
plete address. The MC6801 requires the index 
value to be an immediate value. 

The MC6801 has only one 16-bit Index register and 
an immediate 8-bit value from the second byte of 
the instruction. Hence, the Indexed mode of the 
MC6801 is much more restrictive than that of the 
Z8611. The 8051 must use the accumulator as its 
only Index register, loading the accumulator with 
the register address each time a reference is 
made. Then, using indexing, the data is moved 
into the accumulator, eradicating the previous 
index. This forces a stream of data through the 
accumulator and requires a reload of the index 
before access can be made again. The Z8611 is 
clearly superior to both the MC6801 and the 8051 
in the flexibility of its iridexed addressing mode. 



Short and Long Addressing. Short addressing helps 
to optimize memory space and execution speed. In 
sample applications of short register addressing, 
an eight percent decrease in the number of bytes 
used was recorded. 

All three chips have short addressing modes, but 
the Z8611 has short addressing for both external 
memory and register memory. The 8051 has short 
addressing for the lowest 32 registers only. 

The Z8611 has two different modes for register 
addressing. The full-byte address can be used to 
provide the address, or a 4-bit address can be 
used with the Register Pointer. To use the work- 
ing registers, the Register Pointer is set for a 
particular bank of 16 registers, and then one of 
the 16 registers is addressed with four bits. 
Another feature for addressing external memory is 
the use of a 12-bit address in place of a full 
16-bit address. To use the 12-bit address, one 
port supplies the eight multiplexed address/data 
lines and another port supplies four bits for the 
address. The remaining four bits of the second 
port can be used for I/O. This feature allows 
access to a maximum of 10K bytes of memory. 
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The 8051 uses short addresses by organizing its 
lowest 32 registers into four banks. The bank 
select is located in a 2-bit field in the PSW, 
with three bits addressing the register in the 
bank. 

The MC6801 uses extended addressing for addressing 
external memory. With a special, nonmultiplexed 
expansion mode, 256 bytes of external memory can 
be accessed without the need for an external 
address latch. The MC6801 uses one 8-bit port for 
the address and another port for the data. 
Stacks 



with its 8051 family. The 8031 has no internal 
ROM and the 8751 has 4K of internal EPROM. 

Motorola offers the MC6801, MC6803, MC6803I^R, and 
MC68701. These are all similar except the MC68701 
has 2K bytes of EPROM and the MC6801 has 2K bytes 
of ROM. The MC6803 has no internal ROM and the 
MC6803NR has neither ROM nor RAM on board. 

The Z8613 and the MC68701 are both available now, 
but the 8751 is still unavailable (as of April 
1981). 



The Z8611 and the MC6801 provide for external 
stacks, which require a 16-bit Stack Pointer. 
Internal stacks use only an 8-bit Stack Pointer. 
The 8051 uses only a limited internal stack re- 
quiring an 8-bit Stack Pointer. Using an external 
stack saves the internal RAM registers for 
general-purpose use. 



Summary 

The stack structure of the Z8611 and the MC6801 is 
better than that of the 8051. In most applica- 
tions, the 8051 is more flexible and easier to 
program than the MC6801. The Z8611 is easier to 
use than either the 8051 or the MC6801 because of 
its register flexibility and its numerous combina- 
tions of addressing modes. The 8051 features a 
unique 4.(6n multiply and divide command. 'The 
MC6801 has a multiply, but it takes 10>«.s to per- 
form it. 

In summary, the Z8611 has the most flexible 
addressing modes, the most advanced indexing capa- 
bilities, and superior space- and time-saving 
abilities with respect to short addressing. 



DEVELOPMENT SUPPORT 

All three vendors provide development support for 
their products. This section discusses the dif- 
ferent support features, including development 
chips, software, and modules. 



Software 

Development software includes assemblers, and 
conversion programs. All manufacturers offer some 
or all of these features. 

Since the MC6801 is compatible with the 6800, 
there is no need for a new assembler. The Z8611 
and the 8051 both offer assemblers for their 
products. The Zilog PLZ/ASM assembler generates 
relocatable and absolute object code. PLZ/ASM 
also supports high-level control and data state- 
ments, such as IF... THEN... ELSE. Intel offers an 
absolute macroassembler, ASM51, with their 
product. They also offer a program for converting 
8048 code to 8051 code. 



Modules 

The Z8611 development module has two 64-pin 
development versions of the 40-pin, ROM-masked 
Z8611. Intel offers the EM-51 emulation board, 
which contains a modified 8051 and PROM or EPROM 
in place of memory. Motorola has the MEX6801EVM 
evaluation board for program development. All 
three development boards are available now. 



ADDITIONAL FEATURES 

Additional features include Power Down mode, self- 
testing, and family-compatibility. 



Chips 

Zilog offers an entire family of microcomputer 
chips for product development and final product. 
The Z8611 is a single-chip microcomputer with 4K 
bytes of mask-programmed ROM. For development, two 
other chips are offered. The Z8612 is a 64-pin, 
development version with full interface to ex- 
ternal memory. The Z8613 is a prototype version 
that uses a functional, piggy-back, ilPROM proto- 
pak. The Z8613 can use either a 4K EPROM (2732) 
or a 2K EPROM (2716). Zilog also offers a ROMless 
version in a 40-pin package that has all the fea- 
tures of the Z8611 except on-board ROM (Z8681). 

Intel offers a similar line of development chips 



Power Down Mode 

All three microcomputers offer a Power Down mode. 
The Z8611 and the 8051 save all of their regis- 
ters with an auxilary power supply. The MC6801 
uses an auxiliary power supply to save only the 
first 64 bytes of its register file. 

The Z8611 uses one of the crystal input pins for 
the external power supply to power the registers 
in Power Down mode. Since the XTAL2 input must be 
used, an external clock generator is necessary and 
is input via XTAL1. The 8051 and the MC6801 both 
have an input reserved for this function. The 
MC6801 uses the V^^j, standby pin, and the 8051 uses 
the Vpjj pin. 
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Family Compatibility 



Program Listings 



Another strength of th^ Z8611 is its expansion 
bus, which is completely compatible with the Zilog 
Z-BUS'", This means that all Z-BUS peripherals 
can be used directly with the Z8611., 

The MC6801 is fully compatible with all MC6800 
family products. The 8051 is software compatible 
with the older 8048 series and all others in that 
family^ 



BENCHMARKS 

The following benchmark tests were used in this 
report to compare the Z8611, 8051, and MC6801 : 

• Generate CRC check for 16-bit word. 

• Search for a character in a block of memory. 

• Execute a computed GOTO - jump to one of eight 
locations depending on which of the eight bits 
is set. 

• Shift a 16-word five places to the right. 

• Move a 64-byte block of data from external 
memory to the register file. 

• Toggle a single bit on a port, 

• Measure the subroutine overhead time. 

These programs were selected because of their 
importance in microcomputer applications. Algo- 
rithms that reflect a unique function or feature 
were excluded for the sake of comparison. Al- 
though programs can be optimized for a particular 
chip and for a particular attribute (code density 
or speed) these programs were not. 

The figures cited in this text are taken directly 
from the vendor's documentation. Therefore, the 
cycles given below for the MC6801 and the 8051 are 
in machine cycles and the Z861 1 figures are given 
in clock cycles. The Z8611 clock cycles should be 
divided by six to give the instruction time in 
microseconds. The 8051 and MC6801 machine cycle 
is l^s, and the Z8611 clock cycle is .166/cs at 
12 MHz. 

Because of the lack of availability of the MC6801 
and the 8051, the benchmark programs listed here 
have not yet been run. When these products are 
readily available, the programs will be run and 
later editions of this document will reflect any 
changes in the findings. 







CRC Generation 




8051 






Machine 
Cycles 


Bytes 




MOV 


INDEX, #8 




2 


LOOP: 


MOV 


A, DATA ^ 




2 




XRL 


A, HCHECK 




2 




RLC 


A 




1 




MOV 


A, LCHECK 




2 




XRL 


A, LPOLY 




2 




RLC 


A 




1 




MOV 


LCHECK, A 




2 




MOV 


A, HCHECK 




2 




XRL 


A, HPOLY 




2 




RLC 


A 




1 




MOV 


HCHECK, A 




2 




CLR 


C 




1 




MOV 


A, DATA 




2 




RLC 


A 




1 




MOV 


DATA, A 




2 




DJNZ 


INDEX, LOOP 




3 




RET 






1 




N = 3+17X8 = 139 cycles 








@12 


MHz = 139 its 








Ins 


tructions =18 








Byt 


es = 31 






MC6801 




Machine 










Cycles 


Bytes 




LDAA 


#$08 


2 


2 


LOOP: 


srAA 


COUNT 


3 


2 




LDAA 


HCHECK 


3 


2 




EORA 


DATA 


3 


2 




ROLA 




2 


1 




LOAD 


POLY 


4 


2 




EORA 


HCHECK 


3 


2 




EORB 


LCHECK 


3 


2 




ROLB 




2 


1 




ROLA 




2 


1 




STAD 


LCHECK 


4 


2 




ASL 


DATA 


6 


3 




DEC 


COUNT 


6 


3 




BNE 


LOOP 


4 


2 




RTS 




5 


1 




N = 45X8+7 = 367 cycles 








@4 


MHz = 367 /ts 








Instructions = 15 








Byt 


es = 28 






Z8611 






Clock 
Cycles 


Bytes 




LD 


INDEX, #8 


6 


2 


LOOP: 


LD 


R6, DATA 


6 


2 




XOR 


R6, HCHECK 


6 


1 




RLC 


R6 


6 


2 




XOR 


LCHECK, LPOLY 


6 


2 




RLC 


LCHECK 


6 


2 




XOR 


HCHECK, HPOLY 


6 


2 




RLC 


HCHECK 


6 


2 




RCF 




6 


1 




RLC 


DATA 


6 


2 




DJNZ 


INDEX, LOOP 


12 or 10 


2 




RET 




14 


1 




N = 20+66X7+64 = 546 cycles 






©12 


MHz = 91 ^s 








Instructions = 12 








Byt 


es = 22 
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Character Search Through Block of 40 Bytes 



Shift 16-Bit Word to Right 5-Bits 



8051 



MOV INDEX, #41 
MOV DPTR, //TABLE 
L00P1: DJNZ INDEX, LOOP 2 

SJMP OUT 
L00P2: MOV A, INDEX 

MOVC A, @A+DPTR 
CJNE A, CHARAC, L00P1 
OUT: 

N = 3+39X7+4 = 280 cycles 
@12 MHz = 280/cs 
Instructions = 7 
Bytes = 15 



Machine 
Cycles 

1 
2 
2 
2 
1 
2 
2 



Bytes 

2 
3 
2 
2 
2 
1 
3 



8051 



LOOP: 



MOV 


INDEX #5 


Cycles 


Bytes 
2 


CLR 


C 




1 


MOV 


A, WORD + 1 




2 


RRC 


A 




1 


MOV 


WORD + 1 , A 




2 


MOV 


A, WORK 




2 


RRC 


A 




1 


MOV 


WORD, A 




2 


DJNZ 


INDEX, LOOP 


2 


2 


N = 1+9X5 = 46 Cycles 
ill 2 MHz =: 464«s 






Instructions = 9 






Byt 


es = 15 







MC6801 





LDAB 


#$40 




LDAA 


#CHARAC 




LDX 


#TABLE 


LOOP: 


CMPA 


$0, X 




BEQ 


OUT 




INX 






DECB 






BNE 


LOOP 


OUT: 


- 





Machine 
Cycles 
2 
2 
3 
4 
4 
3 
2 
4 



Bytes 

2 
2 
3 
2 
2 
1 
1 
2 



MC6801 



Machine 



N = 7+40X17 = 687 cycles 
m MHz = 687A.S 
Instructions = 8 
Bytes = 15 

Z8611 Clock 

Cycles 

LD INDEX, #40 6 

LOOP: LD DATA, TABLE (INDEX) 10 

CP DATA, CHARAC 6 

JR Z, OUT 12 or 10 

DJNZ INDEX, LOOP 12 or 30 
OUT: - 



Bytes 

2 
3 
2 
2 
2 







Cycles 


Bytes 




LDX #5 


6 


3 




LOAD WORK 


4 


2 


LOOP: 


LSRD 


3 


1 




DEX 


3 


1 




BNE LOOP 


4 


2 




STAD WORD 


4 


2 




N = 10X5+11 = 61 Cycles 








m MHz = 6^Me 








Instructions = 6 








Bytes = 11 






Z8611 




Clock 








Cycles 


Bytes 




LD INDEX, #5 


6 


2 


LOOP: 


CCF 


6 


1 




RRC WORD + 1 


6 


2 




RRC WORD 


6 


2 




DJNZ INDEX, LOOP 


12 or 10 


2 



N = 6+4X30+28 = 154 Cycles 
@12 MHz = Z6US 
Instructions = 5 
Bytes = 9 



N = 6+38X40 = 1524 cycles 
@12 MHz = 254/i,s 
Instructions = 5 
Bytes =11 
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Computed GOTO 






Move 64-Byte 


Block 




8051 






Machine 
Cycles 


Bytes 


6051 




Machine 
Cycles 


Bytes 




MOV 


INDEX, #40 


1 


2 


MOV 


INDEX, #COUNT 


1 


2 


LOOP 


. MOV 


A, DATA 


1 


2 


LOOP: MOV 


DPTR, #ADDR1 


2 






RLC 


A 


1 


1 


MOVX 


A, (DPTR 


2 






JC 


OUT 


2 


2 


INC 


#ADDR1 


1 






MOV 


A, INDEX 


1 


1 


MOV 


(iADDR2,A 


1 






ADD 


A, #3 


1 


2 


INC 


ADDR2 


1 






MOV 


INDEX, A 


1 


1 


DJNZ 


INDEX, LOOP 


2 






SJMP 


LOOP 


2 


2 


N = 1+9X64 = 577 Cycles 




OUT 


MOV 


DPTR, //TABLE 


2 


3 


mi 


MHz = 577-A'S 








MOV 


A, INDEX 


1 


1 


Instructions = 7 








JMP 


HA+DPTR 


2 


1 


Byt 


es = 10 






TABLE 


: LCALL 


ADDR1 




3 


MC6B01 




Machine 






LCALL 


ADDRN 


2 








Cycles 


Bytes 




N = 1+9X7+11 = 75 Cycl 


es 




LDAB 


#COUNT 


2 


2 




mi 


MHz = 75it^ 






LOOP: LDX 


ADDR1 


4 


3 




Instructions =12 






LDAA 


0, X 


4 


2 




Byt 


es = 21 






I NX 

STAA 

LDX 


ADDR1 
ADDR2 


3 

4 
4 


1 
2 
3 


MC6801 




Machine 




STAA 


0, X 


4 


2 








Cycles 


Bytes 


I NX 




3 


1 




LDAB 


#2 


2 


2 


STX 


ADDR2 


4 


2 




LDX 


TABLE 


3 


3 


DECB 




2 


1 


LOOP: 


RORA 




2 


1 


BNE 


LOOP 


4 


2 




BCS 


OUT 


4 


2 


N = 64X36+2 = 2306 Cycles 






ABX 




3 


1 


m 


MHz =2306-^.3 








JMP 


LOOP 


3 


2 


Ins 


tructions =11 






OUT: 


LDX 
JMP 


0, X 
0, X 


5 
4 


3 
3 


Byt 


es = 21 








N = 8X12+14 = 110 Cycles 














m MHz = IIO-O'S 






Z8611 




Clock 






Instructions = 8 










Cycles 


Bytes 




Bytes = 17 






LD 


INDEX, //COUNT 


6 


2 












LOOP: LDEI 


@ADDR2, (iADDRI 


18 


2 








'" 




DJNZ 


INDEX, LOOP 


12 or 10 


2 



Z8611 



CLR INDEX 
LOOP: INC INDEX 
RLC DATA 
JR NC, LOOP 

LD ADDR, TABLE 1, (INDEX) 
LD ADDR+1, TABLE 2, (INDEX) 10 
JP @ADDR 12 

N = 61-24X7+54 = 228 Cycles 

mi MHz = 384CS 

Instructions = 7 

Bytes = 15 



Clock 
Cycles 

6 

6 

6 

12 or 10 
10 



Bytes 

2 
1 
2 
2 
3 
3 
2 



N = 6+63X30+28 = 1924 Cycles 
mi MHz = 321 -«us 
Instructions = 3 
Bytes = 6 
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Toggle a Port Bit 



Subroutine Call/Return Overhead 



8051 



8051 



Machine 



MC6801 



Z8611 







Machine 






Cycles 


Bytes 






Cycles 


Bytes 


LCALL SUBR 


2 


3 


XRL PC, #YY 




2 


3 








N = 2 Cycles 








_ 






©12 MHz = 2/is 








SUBR: - 






Instructions = 


1 






~, 






Bytes = 3 

1 




Machine 
Cycles 


Bytes 


RET 

N = 4 Cycles 
mi MHz = 4its 
Instructions = 2 
Bytes = 4 


2 


1 


LDAA PORTO 




3 


2 


MC6801 


Machine 




EORA #YY 




2 


2 




Cycles 


Bytes 


STAA PORTO 




3 


2 


JSR SUBR 


9 


2 


N r 8 Cycles 








■" 






m MHz = 8AS 








- 






Instructions = 


3 






SUBR: - 






Bytes = 6 




Clock 




RTS 

N = 14 Cycles 

m MHz = 14^s 


5 


1 








Instructions = 2 










Cycles 


Bytes 


Bytes = 3 






XOR PORTO, #YY 




10 


2 








N = 10 Cycles 








Z8611 


Clock 




©12 MHz = 1.7x1.8 








Cycles 


Bytes 


Instructions = 


1 






CALL ©SUBR 


20 


2 


Byte = 2 








SUBR: - 

RET 

N = 34 Cycles 
mi MHz = 5.7 41s 
Instructions = 2 
Bytes = 3 


14 


1 



Results 

Table 2 summarizes the results of this comparison. 
The relative performance column lists the speeds 
of the MC6801 and 8051 divided by the Z8611 speeds 
(12 MHz). The overall performance averages the 
separate relative performances. The higher the 
number, the faster the Z8611 as compared to the 
MC6801 and the 8051. 

The relative performance figures show that the 
Z8611 runs 50 percent faster than the 8051 and 250 
percent faster than the MC6801. Although speed is 
not necessarily the most important criterion for 
selecting a particular product, the Z8611 proves 
to be an undeniably superior product when speed is 
added to the advantages of programming ease, code 
density, and flexibility. 



287 



Table 2. Benchmark Program Results 



Benchmark 
Test 


MC6801 

(4 MHz) 

cycles time 


8051 

(12 MHz) 

cycles time 


Z8 

(8 MHz) 

cycles time 


Z8 
(12 MHz) 
cycles time 


Relative Performance 
MC6801 8051 


CRC 
Generation 


367 367 


139 139 


546 137 


546 91 


4.03 1.53 


Character 
Search 


687 687 


280 280 


1524 382 


1524 254 


2.70 1.10 


Computed 
GOTO 


110 110 


75 75 


228 57 


228 38 


2.89 1.97 


Shift Right 
5 Bits 


61 61 


46 46 


154 38 


154 26 


2.35 1.78 


Move 

64-byte 

block 


2306 2306 


577 577 


1924 481 


1924 321 


7.18 1.80 


Subroutine 
Overhead 


14 14 


4 4 


34 8.5 


34 5.7 


2.46 0.70 


Toggle a 
Port Bit 


8 8 


2 2 


10 2.5 

Overall 
Performance 


10 1.7 


4.71 1.18 
3.76 1.44 



Note: All times are given in microseconds. 



Table 3. Byte/Instruction/Time Comparison 





Bytes 




Instructions 




Time (microseconds) 


MC6801 


8051 


Z8611 


MC6801 


8051 


Z8611 


MC6801 


8051 


Z8611 


CRC Generation 


28 


31 


22 




15 


18 


12 




367 


139 


91 


Character Search 


.15 


15 


11 




8 


7 


5 




687 


280 


254 


Shift Right 5 Bits 


11 


15 


9 




6 


9 


5 




61 


46 


26 


Computed GOTO 


17 


21 


15 




8 


12 


7 




110 


75 


38 


Move Block 


21 


10 


6 




11 


7 


3 




2306 


577 


321 


Toggle Port Bit 


6 


3 


2 




3 


1 


1 




8 


2 


1.7 


Subroutine Call 


3 


4 


3 




2 


2 


2 




14 


4 


5.7 
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SUMMARY 



The hardware of the three chips compared is very 
similar. The Z8611, however, has several advan- 
tages, the most important of which is its inter- 
rupt structure. It is more advanced than the 
interrupt structures of both the 8051 and the 
MC6801. Other advantages of the ZB611 over either 
the MC6801 or the 8051 include I/O facilities with 
parity detection and hardware handshake and a 
larger amount of internal ROM (the MC6801 has only 
2K bytes). 

Substantial differences are apparent with regard 
to software architecture. The addressing modes of 



the Z8611 are more flexible than those of either 
the MC6801 or the 8051. The Z8611 can use byte- 
saving addressing with working registers, and it 
has short external addresses for saving I/O lines. 
It can also provide for an external stack. The 
register architecture (as opposed to the accumu- 
lator architecture) of the Z8611 saves execution 
time and enhances programming speed by reducing 
the byte count. 

The Z8611 microcomputer stands out as the most 
powerful chip of the three, and concurrently, it 
is the easiest to program and configure. 
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Z86XX Interrupt 
Request Register 



<5>ZiIflG 



Application Brief 



October 1980 



The Interrupt Request Register (IRQ, R250) 
stores requests from the six possible Inter- 
rupt sources (IRQ^-IRQ^) In the Z8600 series 
microcomputer. In addition to other func- 
tions, a hardware reset to the Z8600 disables 
the IRQ register and resets Its request bits. 
Before the IRQ will register requests. It 
must first be enabled by executing an Enable 
Interrupts (El) Instruction, Setting the 
Enable Interrupt bit In the Interrupt Mask 
Register (IMR, R251 ) Is not an equivalent 
operation for this purpose; to enable the 
IRQ, an El Instruction Is required. The 
function of this El Instruction Is distinct 
from Its task of globally enabling the Inter- 
rupt system. Even In a pol led system where 
IRQ bits are tested In software. It Is 
necessary to execute the El, 



The designer must ensure that unexpected and 
undesirable Interrupt requests will not occur 
after the El Is executed. One method of 
doing this Is to reset all Interrupt enable 
bits In the IMR for levels that are possible 
Interrupt sources; the El Instruction may 
then be safely executed. Once El Is exe- 
cuted, the program may Immediately execute a 
Disable Interrupts (Dl) Instruction, The 
code necessary to perform these operations Is 
as fol lows: 

RESET: LD IMR, #JgXX !SET INTERRUPT MASK! 
El ! ENABLE GLOBAL INTER- 

RUPT, ENABLE IRQ! 

where XX has a In each bit position cor- 
responding to the Interrupt level to be 
disabled. If all IMR bits are to be reset, a 
CLR IMR Instruction may be used. 



EI INSTRUCTION 



^- 



^ 



RESET 



J 



INTERRUPT REQUEST REG. 
(IRQ, R250) 



Q-0 RESET 



Z8600 



Figure 1 - IRQ Reset Functional Logic Diagram 
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Z8 Family Software 
Framing Error Detection 



<?>ZiICG 



Application Brief 



October 1980 



The ZIlog Z8600 UART microcomputer is a high- 
performance, single-chip device that incor- 
porates on-chip ROM, R^, parallel I/O, 
serial I/O, and a baud rate generator. The 
UART is capable of ful l-duplex, asynchronous 
serial communication at nine standard 
software-selectable baud rates from 110 to 
19, 2K baud; other nonstandard rates can also 
be obtained under software control. Odd 
parity generation and checking can also be 
selected. 



Three possible error conditions can occur 
during reception of serial data: framing 
error, parity error, and overrun error, A 
framing error condition occurs when a stop 
bit Is not received at the proper time 
(Figure 1), This can result from noise in 
the data channel, causing erroneous detection 
of the previous start bit or lack of detec- 
tion of a properly transmitted stop bit. The 
Z8600 UART does not incorporate hardware 
framing error detection but does facilitate a 
simple, low-overhead software detection 
method , 







LSB 














MSB 


1 









1 


2 


3 


4 


5 


6 


7 


1 

L _J 




START PARITY 


STOP 


BIT DATA BITS (8) (IF BIT 


















ENABLED) 



Ffg» 1 - Asynchronous Data Format 



In the middle of the stop bit time, the Z8600 dition exists and the following code Is used 



UART automatically posts a serial input 
interrupt request on IRQ3. The serial Input 
can also be tested, by reading Port 3 bit 
(P3o) 3s shown In Figure 2, Thus, within 
the interrupt service routine or polling 
loop, it is only necessary to test P3o in 
order to identify a framing error. If P3q Is 
Low when IRQ3 goes High, a framing error con- 



to test this: 

IM P3, #^01 
JR Z, FERR 



! TEST FOR P30 = 1 ! 
! ELSE FRAMING ERROR ! 



The execution time of this framing error test 
is only 5,5 -^s at 8 MHz, In the worst case 
(19,2K baud), this would result In ]% over- 
head. Only five program bytes are required. 




Fig, 2 - Z8600 Serial Input Connection 



Z8 is a trademark of ZIlog, Inc, 
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CONCLUSION While the Z8600 UART does not Incorporate maximum penalty of 1^ at 19. 2K baud using no 
hardware framing error detection, this additional hardware and only five bytes of 
feature can be Implemented In software with a program memory. 



Reprinted with permission of Synertek, Inc. 
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Chapter 1 

Z8 Family Overview 



1.1 INTRODUCTION 

This chapter provides an overview of the architec- 
ture and features of the Z8 Family of products, 
with particular emphasis on those features that 
set this microcomputer apart from earlier micro- 
computers. Detailed information about the archi- 
tecture, address spaces and modes, instruction 
set, external interface, timing, input/output 
operations, and interrupts can be found in subse- 
quent chapters of this manual. 



1.2 FEATURES 

The Z8 microcomputer introduces a new level of 
sophistication to single-chip architecture. Com- 
pared to earlier single-chip microcomputers, the 
Z8 offers faster execution; more efficient use of 
memory; more sophisticated interrupt, input/output 
and bit-manipulation capabilities; and easier sys- 
tem expansion. 

Z8 products offer the standard on-chip functions 
of earlier microcomputers, including: 

• 2K or 4K bytes of ROM 

• 144 8-bit registers 

• 32 lines of programmable I/O 

• Clock oscillator 

• Arithmetic logic unit 

• Parallel and serial ports 



as the basic microcomputer. These products offer 
all the parts and development tools necessary for 
systems development (both hardware and software 
prototyping), field trials (pre-production) and 
full production. For prototyping ayid preproduc- 
tion, or where code flexibility is important, the 
Z8603/13 Protopack, 2K and 4K EPROM-based parts 
are the most appropriate. The ROM-based Z8601/11 
microcomputers are used in high-volume production 
applications after the software has been per- 
fected. For ROMless applications^ two versions of 
the Z8 microcomputer are available: the 40-pin 
Z8681/82 and the 64-pin Z8612. In addition, there 
is a military version of the Z8611 4K ROM device, 
available in both 40-pin ceramic and 44-pin lead- 
less chip carrier packages. 

The Z8671 MCU is a complete microcomputer prepro- 
grammed with a BASIC/Debug Interpreter. This 
device, operating with both external ROM or RAM 
and on-chip memory registers, is suitable for most 
industrial control applications, or whenever fast 
and efficient program development is necessary. 

The Z8 microcomputer is well-suited for dedicated 
control applications in real-time mode. Since 
speed is a key consideration in such applications, 
the Z8 Family is available in both 8 and 12 MHz 
versions, supported by either of two development 
modules: the Development Module (DM) or the 
Z-SCAN 8. The Z-SCAN module provides (ICE) in- 
circuit emulation capability. 



Beyond these basic features, the Z8 Family offers 
such advanced characteristics as: 



1 .2.1 Instruction Set 



Two counter/timers 

Six vectored interrupts 

UART for serial I/O communication 

Stack functions 

Power-down option 

TTL compatibility 

Optimized* instruction set 

BASIC/Debug interpreter 



The Z8 instruction set, consisting of 43 basic 
instructions, is optimized for high-code density 
and reduced execution time. The 47 instruction 
types and six addressing modes — together with the 
ability to operate on bits, 4-bit words, BCD 
digits, 8-bit bytes, and 16-bit words — make for a 
code-efficient, flexible microcomputer. 



All members of the Z8 Family are variations of the 
basic Z8 microcomputer, the Z8601/11. The Z8 
Family includes a development device (Z8612), a 
ROMless device (Z8681/82), BASIC/Debug Interpreter 
(Z8671), a Protopack emulator (Z8603/i3), as well 



1 .2.2 Architecture 

Z8 architecture offers more flexibility and per- 
formance than previous A/B accumulator designs. 
All 128 general-purpose registers, including 
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dedicated I/O port registers, can be used as 
accumulators. This eliminates the bottleneck com- 
monly found in A/B devices, particularly in high- 
speed applications such as disk drives, printers 
and terminals. In addition, the registers can be 
used as address pointers for indirect addressing, 
as index registers or for implementing an on-chip 
stack. Speed of execution and smooth programming 
are supported by a "working register area" — short 
4-bit register addresses. 



Table 1-1 lists the basic characteristics of the 
members of the Z8 Family. As shown, the major 
differences between the products are in their 
physical packaging and the manner in which address 
space is handled. An overall description for each 
Z8 type is given in the following sections. 
Variations within each group are specified where 
applicable. 



1.3 NICRQCQHPUTERS (Z8601/Z8611) 

The Z8 can be a stand-alone microcomputer with 
either 2K bytes (28601) or 4K bytes (Z8611) of 
internal ROM, a traditional microprocessor that 
can manage up to 124K bytes (Z8601) or 120K bytes 
(Z8611) of external memory, or a parallel proces- 
sing element in a system with other processors and 
peripheral controllers linked by a Z-6US. In all 
configurations, a large number of device pins are 
available for I/O. Key features of the Z8601/11 
microcomputer include: 

• RQH 2K-byte (Z8601) or 4K-byte (Z8611) PrograM 
Neaory. This ROM is mask-programmed during 
production with user-provided programs. 

• 144-byte RAN Register File. The internal 
register organization of the Z8 microcomputer 
centers around a 144-byte file composed of 124 
general-purpose registers, 16 status and 
control registers, and 4 I/O port registers. 
Either an 8-bit or a 4-bit address mode can be 
used to access the register file. When the 
4-bit mode is used, the register file is 
divided into 9 groups of 16 working registers 
each. A Register Pointer uses short- format 
instructions to quickly access any one of the 
nine groups. Use of the 4-bit addressing mode 
decreases access time and improves throughput. 

• Prograauble Counter/Iiaers. Two 8-bit coun- 
ter/timer circuits are provided, each driven by 
its own prescaler. Both the counter/timers and 
their prescaler circuits are programmable. 



• I/O Lines/Ports. The Z8 microcomputer provides 
32 input/output lines, arranged as 4 8-bit 
ports. Under software control, the I/O ports 
(Ports 0, 1, 2, 3) can be programmed as input, 
output, or additional address lines. The I/O 
ports can also be programmed to provide timing, 
status signals, interrupt inputs and serial or 
parallel I/O (with or without handshake). 

• Vectored Interrupts. The Z8 MPU permits the 
use of six different interrupts from any of 
eight different sources. Four Port 3 lines 
(P3o-P33), serial input pin (P3o), the serial 
output pin (P37) and both counter/timer 
circuits may be interrupt sources. All 
interrupts are vectored and are both maskable 
and prioritized. 

• Oscillator Circuit. An oscillator circuit that 
can be driven from an external clock or crystal 
is provided on the Z8 microcomputer. The 
oscillator will accept an input frequency of up 
to 12 MHz on the XTAL1 and XTAt2 pins provided. 

• Optional Power-Oown Feature. This option 
permits normal input power to be removed from 
the chip without affecting the contents of the 
register file. The power-down * function 
requires an external battery backup system. 

Pin functions and descriptions for the Z8601/11 
microcomputer can be found in Chapter 6. 



1.4 DEVCLOPNCNT DCVICE (Z8612) 



UART (Universal Asynchronous Receiver Tranaeit- 
ter). A full-duplex UART is provided to 
control serial data communications. One of the 
on-chip counter/timer circuits provides the 
required bit rate input to enable the UART to 
operate at a maximum data transfer rate of 
93.75K bits per second at a crystal frequency 
of 12 MHz. 



A development device allows users to prototype a 
system with an actual hardware device and to, 
develop the code that is eventually mask-pro- 
grammed into the on-chip ROM of the Z8601 or Z8611 
microcomputer. Development devices are also use- 
ful in applications where production volume does 
not justify the expense of a ROM system. The 
Z8612 development device is identical to its 
equivalent microcomputer, the Z8611, with the fol- 
lowing exceptions: 
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• No internal ROM is provided, so that code is 
developed in an off-chip memory. 

• The normally internal ROM address and data 
lines are buffered and brought out to external 
pins to interface with the external memory. 



• The device package is enlarged in order to 
accommodate the new control, address, and data 
lines. 

Pin functions and descriptions for the development 
device can be found in the Appendix. 



• Control lines are added to interface with 
external program memory. 



Table 1>1. Z8 Faiily of Products 



Product 



ROH 
Part Capacity PrograMiable Dedicated PCB 
Number (Bytes) I/O Pins I/O Pins Footprint 



Comments 



2K ROM 



Z8601 2K 



32, 4 ports 8 Power, 
Control 



40 Pin Masked ROM part, used 

primarily for high volume 
production. 



2K Protopack Z8603 



32, 4 ports 8 Power, 
Control 
plus 
24 EPROM 



40 Pin Piggyback part used where 
program flexibility is 
required (prototyping). 



4K ROM 



Z8611 



4K 



32, 4 ports 8 Power, 
Control 



40 Pin Masked ROM part, used 

primarily for high volume 
production. 



4K Develop- 
ment part 



Z8612 



32, 4 ports 



8 Power, 
Control 
plus 24 
external 
memory 



64 Pin 



ROMless part used primarily 
in development systems. 



4K Protopack Z8613 



32, 4 ports 8 Power, 
Control 
plus 
24 EPROM 



40 Pin Piggyback part used where 
program flexibility is 
required (prototyping). 



BASIC/ 
Debug 



Z8671 2K 



32, 4 ports 8 Power, 
Control 



40 Pin BASIC/Debug part used in 
low volume applications. 



ROMless 



Z8681/82 



24, 3 ports 8 Power, 
Control 
plus 8 
external 
memory 



40 Pin Low cost ROMless production 
part with reduced I/O. 
Program memory is external. 
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1.5 PROTOPACK EMULATOR (Z8603/13) 



1 i7 ROMLESS MICROCOMPUTER (Z8681/82) 



The Protopack emulator devices, Z8603 and Z8613, 
are ROMless versions of their equivalent microcom- 
puters (Z8601 and Z8611 , respectively). The emu- 
lators differ from development devices in two 
wayss they use the same pinout as the microcom- 
puters, and an external ROM or EPROM can be 
plugged into the top of the package. The emulator 
package allows for flexibility of application, 
since it can be used in either prototype or final 
pc boards, yet still allows for program develop- 
ment. 

When the final program is developed, it can be 
mask-programmed into the Z8601/11 which then 
replaces the emulator. The emulator is also use- 
ful in small volume applications where the cost of 
mask-programming is prohibitive or where program 
flexibility is desired. 

Physical description for the Protopack emulator is 
found in the Appendix. 



The Z8681 and Z8682 ROMless microcomputers provide 
virtually all of the functions of the standard Z8 
microcomputer without the need to mask-program 
on-chip ROM. This microcomputer is similar to the 
Z8601 version except that there is no on-chip pro- 
gram memory. Unlike the ROMless development and 
Protopack devices the Z8681/82 has no additional 
address or address control lines nor does it carry 
a plug-in piggyback memory module. Use of exter- 
nal memory rather than internal ROM enables this 
Z8 device to be used in low volume applications or 
where code flexibility is required. The use of 
Ports and 1 to interface external memory leaves 
16 to 24 lines for I/O. 

Since Port 1 is dedicated as an 8-bit multiplexed 
Address/Data bus, and Port lines can be pro- 
grammed as address bits, the resulting 16-bit 
addresses can directly address up to 64K bytes of 
memory for the Z8681 and 62K bytes for the Z8682. 
(The Z8682 MCU cannot address the lower 2K bytes 
of memory); 



1.6 BASIC/DEBUG INTERPRETER (Z8671) 

The Z8671 MCU is a complete microcomputer prepro- 
grammed with a BASIC/Debug interpreter. BASIC/ 
Debug can directly address the Z8671's internal 
registers and all external memory. It can quickly 
examine and modify any external memory location or 
I/O port, and can call machine language subrou- 
tines to increase execution speed. 

The Z8671 MCU has a combination of software and 
hardware that is ideal for most industrial control 
applications. Along with the functions mentioned 
above, this microcomputer has a self-contained 
line editor for interactive debugging which fur- 
ther speeds program development. In addition the 
BASIC/Debug Interpreter allows program execution 
on powet-up or reset, without operator interven- 
tion. / 

Two kinds of memory exist in the Z8671 device: 
on-chip registers and external ROM or RAM. The 
BASIC/Debug interpreter is located in the 2K bytes 
of on-chip ROM. Maximum addressing capability is 
62K bytes of external program memory and 62K bytes 
of data memory. In addition, 32 I/O lines, a 144- 
byte register file, on-board UART and two coun- 
ter/timers are provided. 

Pin descriptions and functions are the same as 
those for the Z8601/11 basic microcomputer 
(Chapter 6). 



The address capability of the Z8681/82 can be 
doubled by programming output P3^ of Port 3 as 
Data Memory (DM) select signal. The two states of 
this signal can be used with the 16-bit addresses 
to identify two separate external address spaces, 
thus increasing external address space to 128K 
bytes for the Z8681 and 124K bytes for the Z8682. 

Pin functions and descriptions for the Z8681/82 
microcomputer can be found in Chapter 7. 



1 .8 APPLICATIONS 

Z8 microcomputers are most often used in high-per- 
formance, dedicated applications. Such special- 
ized functions were previously accomplished with 
TTL logic, TTL logic plus a low-end MCU, or a 
microprocessor and peripherals. Some typical 
applications include.: 

• Disc drive controller 

• Printer cqntroller 

• Terminals 

• Modems 

• Industrial controllers 

• Key telephones 

• Telephone switching systems 

• Arcade games and intelligent home games 

• Process control 

• Intelligent instrumentation 

• Automotive mechanisms 
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Following are brief descriptions for a few Z8 
applications. 

Printers. Input data (typically transmitted via a 
terminal or computer) can be sent to the Z8 on 
either a serial or parallel port. The ZB then 
transfers the data into the external, RAM buffer 
via another parallel port, where it can operate on 
the data before output to the printing mechanism. 



Disk. Disk operations are read or write, with 
input received from either the disk or the compu- 
ter. Data is transferred to the buffer memory a 
sector (128, 256, 512, 1024 bytes) at a time via 
the Z8, operated on as required, and subsequently 
output to the disk or computer. 

Teminal. Input is received from either the key- 
board or a computer. The Z8 device must maintain 
at least an input buffer and often the screen RAM. 
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Chapter 2 
Architectural Overview 



2.1 INTRODUCTION 

The Z8 is a versatile single-chip microcomputer. 
Because its multiplexed address/data bus is merged 
with several I/0-oriented ports, the Z8 can func- 
tion as either an I/0-intensive or a memory- 
intensive microcomputer. One key advantage to 
this organization is that external memory can be 
addressed while maintaining many of the I/O 
lines. Figure 2-1 shows the Z8 block diagram. 



2.2 ADDRESS SPACES 

To provide for both I/0-intensive and memory- 
intensive applications, the ZB supports three 
basic address spaces: 



• Program memory (internal and external) 

• Data memory (external) 

• Register file (internal) 

A maximum of 64K bytes of program memory are 
directly addressable. In the Z8601 and Z8611 
microcomputers, internal program memory consists 
of a mask-programmed ROM. The size of this 
internal ROM is 2K bytes for the Z8601 and 4K 
bytes for the Z8611. In one member of the Z8 
family, the Z8681 , all of the program memory is 
externally addressable. 

Data memory space is always external to the Z8 
microcomputer and is 62K bytes in size for the 
Z8601 and Z8682, and 60K and 64K bytes in size 
respectively for the Z8611 and Z8681 . 
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Figure 2-1. Z8 Block Diagraa 
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2.3 REGISTER FILE 

The Z8's register-oriented architecture centers 
around an internal register file composed of 124 
general-purpose registers, 16 CPU and peripheral 
control registers, and 4 I/O port registers. All 
registers are eight bits. Any general-purpose 
register can be used as an accumulator, an address 
pointer, or an index, data, or stack register. 



Logical, Shift, Rotate and Load instructions oper- 
ate on bytes in the register file. Bytes in data 
memory are only affected by Load instructions. 

Sixteen-bit arithmetic instructions (Increment 
Word and Decrement Word) operate on words in the 
register file. 



2.3.4 Addressing Modes 



2.3.1 Register Pointer 



The addressing modes of the Z8 CPU are: 



A Register Pointer logically divides the register 
file into 9 working register groups of 16 regis-, 
ters each, which allows for fast context switching 
and shorter instruction formats. 



2.3.2 Instruction Set 

The Z8 CPU has an instruction set designed for the 
large register file. The instruction set provides 
a full complement of 8-bit arithmetic and logical 
operations. BCD operations are supported using a 
decimal adjustment of binary values, and 16-bit 
quantities for addresses and counters can be 
incremented and decremented. Bit manipulation and 
Rotate and Shift instructions complete the data 
manipulation capabilities of the Z8 system. No 
special I/O instructions are necessary since the 
I/O is mapped into the register file. 



2.3.3 Data Types 



The Z8 CPU supports operations 
digits, bytes, and 2-byte words. 



on bits, BCD 



Bits in the register file can be tested, set, 
cleared, and complemented. Bits within a byte are 
numbered from to 7 with bit being the least 
significant (right-most) bit (Figure 2-2). 



[dT Dg Dg D4 D3 D2 Di "dH 
Figure 2-2. Bits in Register 



Register 

Indirect Register 

Immediate 

Direct Address 

Indexed (with a short 8-bit displacement) 

Program Counter Relative 



Register, Indirect Register, and Immediate 
addressing modes are available for Load, Arith- 
metic, Logical, Shift, Rotate, and Stack instruc- 
tions. Conditional Jumps use both Direct Address 
and Program Counter Relative, while Jump and Call 
instructions use Direct Address and Indirect Reg- 
ister addressing modes. 



2.4 I/O OPERATIONS 

The Z8 has 32 pins dedicated to input and output. 
These lines are grouped into four ports of eight 
lines each. Ports can be programmed as input, 
output, or bidirectional. Under software control, 
the ports provide timing, status signals, address 
outputs, and serial or parallel I/O with or with- 
out handshake. Multiprocessor system configura- 
tions are also supported. 



2.4.1 Timers 

To unburden the program from real-time problems 
such as serial data communications and counting/ 
timing, the Z8 contains an on-chip universal asyn- 
chronous receiver/transmitter (UART) and two coun- 
ter/timers with a large number of user-selectable 
modes. One on-chip timer provides the bit rate 
input to the UART during communications. 



Manipulation of BCD digits packed two-to-a-byte is 
accomplished by a Decimal Adjust instruction and a 
Swap instruction. Decimal Adjust is used after a 
binary addition or subtraction on BCD digits. 



2.4.2 Interrupts 

I/O operations can be interrupt-driven or polled. 
The Z8 supports six vectored interrupts that can 
be masked and prioritized. 



307 



2.5 OSCILLATOR 2.6 PROTOPACK 

The Z8 offers an on-chip oscillator and an The Z8 Protopack allows the user to prototype 
optional power-down mechanism that can be used to system hardware and develop software that is 
maintain the contents of the register file with a eventually to be mask-programmed into the on-chip 
low-power battery. ROM of the 2K byte (Z8601) or the 4K byte (Z8611) 

version of the Z8. 
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3.1 INTRODUCTION 

Three address spaces are available in the Z8 
microcomputer: 

• The CPU Register File contains addresses for 
all general-purpose, peripheral, control, and 
I/O port registers. 

• The CPU Program Memory contains addresses for 
all memory locations having executable code 
and/or data. 

• The CPU Data Memory contains addresses for all 
memory locations that hold data only. 

These address spaces are described in detail in 
the following sections. 



3.2 CPU REGISTER FILE 

The register file totals 256 consecutive bytes, of 
which 144 have been implemented. (Unused register 
space is reserved for future expansion.) The reg- 
ister file consists of 4 I/O ports (R0-R3), 124 
general-purpose registers (R4-R127), 9 peripheral 
registers (R240-R248), and 7 control registers 
(R249-R255). Figure 3-1 shows the layout of the 
register file, including register names, loca- 
tions, and identifiers. 

Registers can be accessed as either 8- or 16-bit 
registers using Direct, Indirect, or Indexed 
addressing. All 144 registers can be referenced 
or modified by any instruction that accesses an 
8-bit register, without the need for special 
instructions. Registers accessed as 16-bits are 
treated as even-odd register pairs (there are 72 
valid pairs). In this case, the data's MSB is 
stored in the even-numbered register, while the 
LSB goes into the next higher odd-numbered 
register (Figure 3-2). 
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Figure 3-1. Register File 



MSB LSB I n =: EVEN ADDRESS 



Rn Rn+1 



Figure 3-2. 16-Bit Register Addressing 
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By using logical instructions and a mask, indivi- 
dual bits within registers can be accessed for bit 
set, bit clear, bit complement, or bit test opera- 
tions. For example, the instruction AND R, MASK 
performs a bit clear operation. 

When instructions are executed, registers are read 
when defined as sources and written when defined 
as destinations. All general -purpose registers 
function as accumulators, address pointers, index 
registers, stack areas, or scratchpad memory. 

28 instructions can access 8-bit registers and 
register pairs (16-bit) using either 4-bit or 
8-bit address fields. Mith 4-bit addressing, the 
register file is logically divided into 9 groups 
of 16 working registers as shown in Figure 3-3. A 
Register Pointer (one of the control registers) 
contains the base address of the active working 
register group. 

When accessing one of the working registers, the 
4-bit address is concatenated with the upper four 
bits of the Register Pointer, thus forming an 
8-bit address. Figure 3-4 illustrates this opera- 
tion. Since working registers are typically 
specified by short format instructions, there are 
fewer bytes of code needed, which reduces execu- 
tion time. In addition, when processing interrupts 
or changing tasks, the Register Pointer speeds 
context switching. A special Set Register Pointer 
(SRP) instruction sets the contents of the Regis- 
ter Pointer. 



3.2.1 Error Conditions 

Registers must be correctly used because certain 
conditions produce inconsistent results and should 
be avoided: 



• Registers R243 and R245-R249 are write-only 
registers. If an attempt is made to read these 
registers, SFF is returned i% is a prefix that 
indicates hexadecimal notation). 

• Whetn register R253 (Register Pointer) is read, 
all Os are returned in the least significant 
four bits. 



'7 h h ^ I 
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file address 
-provided by 
the instruction 
points to the 
specified 
register. 



Figure 3-3. Working Register Groups 
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figure 3-4. Working Register Addressing 
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• When registers RO and R1 (Ports and 1) are 
defined as address outputs, they will return 
Is in each address bit location when read. 

• Writing to bits which are defined as address 
output, timer output, serial output, or hand- 
shake output will have no effect. 

• Instruction DJNZ uses a general register as a 
counter. Only registers R4-R127 can be used 
with this instruction. 



3.3 CPU CONTROL AM) PERIPHERAL REGISTERS 

The Z8 control registers govern the operation of 
the CPU. Any instruction that references the 
register file can access these control registers. 
Available control registers are: 



3.4 CPU PROGRAM HENORY 

The Z8 can access 64K bytes of program memory with 
the 16-bit Program Counter, In the Z8601 , the 
lower 2K bytes of the program memory address space 
are internal ROM, while in the Z8611 the lower 4K 
bytes are internal ROM. In the Z8682 the lower 2K 
bytes are not accessible. 

To access program memory outside the on-board ROM 
space. Port and Port 1 can be configured as a 
memory interface. For example. Port 1 as a multi- 
plexed Address/Data port (ADp-ADy) provides 
Address lines Ag-Ay and Data lines Dg-Dy. Port 
can be configured for an additional four or eight 
address lines (A8-Ai>| or I^q-^'\^)' This memory 
interface is supported by the control lines AS 
(Address Strobe), DS (Data Strobe) and R/W 
(Read/Write). 



• Interrupt Priority register (IPR) 

• Interrupt Mask register (IMR) 

• Interrupt Request register (IRQ) 

• Program Control flags (FLAGS) 

• Register Pointer (RP) 

• Stack Pointer - high-byte (SPH) 

• Stack Pointer - low-byte (SPL) 

The Z8 uses a 16-bit Program Counter (PC) to 
determine the sequence of current program instruc- 
tions. The PC is not an addressable register. 

Peripheral registers are used to transfer data, 
configure the operating mode, and control the 
operation of the on-chip peripherals. Any 
instruction that references the register file can 
access peripheral registers. The peripheral regis- 
ters are: 

• Serial I/O (SIO) 

• Timer Mode (TMR) 

• Timer /Counter (TO) 

• TO Prescaler (PREO) 

• Timer /Counter 1 (T1) 

• T1 Prescaler (PRE1) 

• Port 0-1 Mode (P01M) 

• Port 2 Mode (P2M) 

• Port 3 Mode (P3M) 

In addition, the four port registers (P0-P3) are 
considered to be peripheral registers. 

The functions and applications of control and 
peripheral registers are described in subsequent 
sections of this manual. 



In the ROMless Z8681 version. Port 1 is automati- 
cally a multiplexed Address/Data port. Port 
must be configured for additional address lines as 
needed. 

The^ first 12 bytes of program memory are reserved 
for the interrupt vectors. Addresses 0-11 contain 
six 16-bit vectors that correspond to the six 
available interrupts. Figure 3-5 illustrates the 
order of 16-bit data stored in program memory. 
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Figure 3~3b. Z8611 Program Hemory Hap 
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Figure 3-3d. Z8682 Program Memory Map 



When an interrupt occurs, the address stored in 
the interrupt 's vector location points to a ser- 
vice routine. This routine assumes program con- 
trol. 

The first 2K bytes of program memory are not 
addressable in the Z8682 ROMless version. 
Beginning at address 2048 the first 18 bytes 
contain interrupt vectors which are Jump Direct 
instructions. When an interrupt occurs, the Z8682 
executes the corresponding Jump to interrupt. 

The first address available for a user program is 
location 12. This address is loaded into the 
Program Counter after a hardware reset. 

The first address available for a user program in 
the Z8682 is location 2066 (Hexadecimal ?o812). 
This address is loaded into the Program Counter 
after a hardware reset. 



Figure 3-5c. Z8681 Program Memory Map 
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3.5 CPU DATA HEHORY 

Up to 64K bytes of external data memory can be 
accessed in the 28 microcomputer. As shown in 
Figure 3-6, the origin, and hence, the actual size 
of data memory is device-dependent. The origin of 
data memory is the same as the starting address of 
external program memory. 

Like external program memory, external data memory 
Address/Data lines are provided by Port 1 for 
8-bit addresses, and by Ports and 1 for 12-bit 
and 16-bit addresses. 

External data memory can be included with or sep- 
arated from the external program memory addressing 
space. When data memory is separated from program 
memory, the Data Memory output (DM) is used to 
select between data and program memories. 
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Figure 3>6b. Z8611 Data Henory Hap 
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Figure 3-6a. Z8601 or Z8682 Data Memory Hap 
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3.6 CPU STACKS 

Stack operations can occur in either the register 
file or data memory. Under software control, 
Port and 1 Mode register (R258) selects stack 
location. 

The register pair R254 and R255 forms the 16-bit 
Stack Pointer (SP) which is used for all stack 
operations. The stack address is stored with the 
MSB in R254 and LSB in R255 (Figure 3-7). 



The stack address is decremented prior to a Push 
operation and incremented after a Pop operation. 
The stack address always points to the data stored 
on the top-of-stack. The Z8 stack is a return 
stack for Call instructions and interrupts as well 
as a data stack. During a Call instruction, the 
contents of the PC are saved on the stack. The PC 
is restored during a Return instruction. Inter- 
rupts cause the contents of the PC and Flag regis- 
ter to be saved on the stack. The IRET instruc- 
tion restores them (Figure 3-8). 



LOWER BYTE I STACK POINTER LOW 



UPPER BYTE I STACK POINTER HIGH 



When the Z8 is configured for an internal stack 
(i.e., using the register file), register R255 
serves as the Stack /Pointer. The value in R254 is 
ignored and can be used as a general-purpose 
register. However, an overflow or underflow can 
occur when stack address is incremented or 
decremented during normal stack operations. 



Figure 3-7. Stack Pointer 
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Figure 3-8. Stack Operations 
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4.1 INTRODUCTION 

The Z8 microcomputer provides six addressing 
modes: 

• Register (R) 

• Indirect Register (IR) 

• Indexed (X) 

• Direct (D) 

• Relative (RA) 

• Immediate (IM) 



Pointer (R253) with the 4-bit working register 
address supplied by the instruction. 

Registers can be used in pairs to designate 16-bit 
values or memory addresses. A register pair must 
be specified as an even-numbered address in the, 
range 0, 2,...., 14. 

Addressing modes are instruction-specific. 
Section 5.4 discusses each addressing mode as it 
corresponds to particular instructions. 



With the exception of immediate data and condition 
codes, all operands are expressed as register 
file, program memory, or data memory addresses. 
Registers are accessed using 8-bit addresses in 
the range 0-127 and 240-255. 

Working registers are accessed using 4-bit 
addresses in the range 0-15. The address of the 
register being accessed is formed by the concate- 
nation of the upper four bits in the Register 



In the following definitions, the use of 
"register" also implies register pair, working 
register, or working register pair. 



4,2 REGISTER ADDRESSING (R) 

In the Register addressing mode, the operand value 
is the contents of the specified register or 
register pair (Figures 4-1 and 4-2). 



PROGRAM MEMORY 



REGISTER FILE 



8BIT REGISTER 
FILE ADDRESS . 



^5K- 



ONEOPERAND 
INSTRUCTION 
EXAMPLE ' 



7^ 



dst 



OPCODE 



POINTS TO ONE REGISTER 
IN REGISTER FILE 



VALUE USED IN 
INSTRUCTION EXECUTION 




Figure 4-1 . Register Addressing 
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Figure 4-2. Working-Register Addressing 
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4.3 INDIRECT REGISTER ADDRESSING (IR) 



4.4 INDEXED ADDRESSING (X) 



In the Indirect Register addressing mode, the con- 
tents of the specified register is the address of 
the operand (Figures 4-3 and 4-4). 

Depending upon the instruction selected, the 
address points to a register, program memory, or 
an external data memory location. 



The Indexed addressing mode is used only by the 
Load (LD) instruction. An indexed address consists 
of a register address offset by the contents of a 
designated working register (the Index). This 
offset is added to the register address to obtain 
the address of the operand. Figure 4-5 illus- 
trates this addressing convention. 



When accessing program memory or external data 
memory, register pairs or working register pairs 
are used to hold the 16-bit addresses. 
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Figure 4-3. Indirect Register Addressing to Register File 



Figure 4-4. Indirect Register Addressing to Proigram or Data Neniory 
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4.3 DIRECT ADDRESSING (DA) 

The Direct addressing mode, as shown in Figure 
4-6, specifies the address of the next instruction 
to be executed. Only the Conditional Jump (JP) 
and Call (CALL) instructions use this addressing 
mode. 



4.6 RELATIVE ADDRESSING (RA) 



two's-complement signed displacement in the range 
of -128 to +127. This is added to the contents of 
the PC to obtain the address of the next 
instruction to be executed. The PC (prior to the 
add) consists of the address of the instruction 
following the Jump Relative (JR) or Decrement and 
Jump if Nonzero (DJNZ) instruction. JR and DJNZ 
are the only instructions that use this addressing 
mode.. 



In the Relative addressing mode, illustrated in 
Figure 4-7, the instruction specifies a 
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Figure 4-5. Indexed Addressing 
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Figure 4-6. Direct Addressing 



Figure 4-7. Relative Addressing 
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4.7 IMCDIATE DATA ADDRESSING (IN) 

Immediate data is considered an "addressing mode" 
for the purposes of this discussion. It is the 
only addressing mode that does not indicate a reg- 
ister or memory address as the source operand; the 
operand value used by the instruction is the value 
supplied in the operand field itself. Because an 
immediate operand is part of the instruction, it 
is always located in the program memory address 
space. 



INSTRUCTION 



WORD(S) 



OPERATION 



THE OPERAND VALUE IS IN THE INSTRUCTION. 



Figure 4-8. Iniiediate Data Addressing 
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3.1 FUNCTIONAL SUMMARY 



Logical Instructions 



Z8 instructions can be divided functionally into 
the following eight groups: 

• Load 

• Arithmetic 

• Logical 

• Program Control 

• Bit Manipulation 

• Block Transfer 

• Rotate and Shift 

• CPU Control 

The following summary shows the instructions 
belonging to each group and the number of operands 
required for each. The source operand is "src", 
"dst" is the destination operand, and "cc" is a 
condition code. 



Mnemonic Operands 

AND dst, src 

COM dst 

OR dst, src 

XOR dst, src 



Instruction 

Logical And 
Complement 
Logical Or 
Logical Exclusive Or 



Program-Cohtrol Instructions 



Mnemonic 


Operands 


Instruction 


CALL 


dst 


Call Procedure 


DJNZ 


r,dst 


Decrement and Jump NonO 


IRET 




Interrupt Return 


JP 


cc,dst 


Jump 


JR 


cc,dst 


Jump Relative 


RET 




Return 



Load Instructions 



Mnemonic 


Operands 


Instruction 


CLR 


dst 


Clear 


LD 


dst, src 


Load 


LDC 


dst, src 


Load Constant 


LDE 


dst, src 


Load External 


POP 


dst 


Pop 



PUSH 



Push 



Bit -Manipulation Instructions 



Mnemonic 


Operands 


Instruction 


TCM 


dst, src 


Test Complement Under Mask 


TM 


dst, src 


Test Under Mask 


AND 


dst, src 


Bit Clear 


OR 


dst , src 


Bit Set 


XOR 


dst, src 


Bit Complement 



Block-Transfer Instructions 



Arithmetic Instructions 



Mnemonic 


Operands 


Instruction 


ADC 


dst, src 


Add With Carry 


ADD 


dst, src 


Add 


CP 


dst, src 


Compare 


DA 


dst 


Decimal Adjust 


DEC 


dst 


Decrement 


DECW 


dst 


Decrement Word 


INC 


dst 


Increment 


INCW 


dst 


Increment Word 


SBC 


dst, src 


Subtract With Carry 


SUB 


dst, src 


Subtract 



Mnemonic 


Operands 


Instruction 


LDCI 


dst, src 


Load Constant Auto- 
increment 


LDEI 


dst, src 


Load External Auto- 
increment 



Rotate and Shift Instructions 



Mnemonic 


Operands 


Instruction 


RL 


dst 


Rotate Left 


RLC 


dst 


Rotate Left Through Carry 


RR 


dst 


Rotate Right 


RRC 


dst 


Rotate Right Through Carry 


SRA 


dst 


Shift Right Arithmetic 


SWAP 


dst 


Swap Nibbles 
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CPU Control Instructions 



Mnemonic Operand 



Instruction 



CCF 

DI 

EI 

NOP 

RCF 

SCF 

SRP 



Complement Carry Flag 

Disable Interrupts 

Enable Interrupts 

No Operation 

Reset Carry Flag 

Set Carry Flag 

Set Register Pointer 



5.2.1 Carry Flag (C) 

The Carry flag is set to 1 whenever the result of 
an arithmetic operation generates a carry out of 
or a borrow into the high order bit 7; otherwise, 
the Carry flag is cleared to 0. 

Following Rotate and Shift instructions, the Carry 
flag contains the last value shifted out of the 
specified register. 



5.2 PROCESSOR FLAGS 



An instruction can set, reset, or complement the 
Carry flag. 



The Flag register (R252) informs the user about 
the current status of the Z8. The flags and their 
bit positions in t^e Flag register are shown in 
Figure 5-1. 

R252 FLAGS 
Flag Register 

(FCh; Read/Write) 



\h. 



Di 



L 



USER FLAG F1 
USER FLAG F2 
HALF CARRY FLAG 
DECIMAL ADJUST FLAG 
OVERFLOW FLAG 
SIGN FLAG 
ZERO FLAG 
CARRY FLAG 



RETI changes the value of the Carry flag when the 
saved Flag register is restored. 



5.2.2 Zero Flag (Z) 

For arithmetic and logical operations, the Zero 
flag is set to 1 if the result is zero; otherwise, 
the Zero flag is cleared. 

If the result of testing bits in a register is 0, 
the Zero flag is set to 1; otherwise the flag is 
cleared. 

If the result of a Rotate or Shift operation is 0, 
the Zero flag is set to 1; otherwise, the flag is 
cleared. 

RETI changes the value of the Zero flag when the 
saved Flag register is restored. 



Figure 5-1. Flag Register 



5.2.3 Sign Flag (S) 



The Z8 Flag register contains six bits of status 
information which are set or cleared by CPU opera- 
tions. Four of the bits (C, V, Z and S) can be 
tested for use with conditional Jump instruc- 
tions. Two flags (H, D) cannot be tested and are 
used for BCD arithmetic. 

The two remaining bits in the Flag register (F1, 
F2) are available to the user, but they must be 
set or cleared by instruction and are not usable 
with conditional Jumps. 

As with bits in the other control registers. Flag 
register bits can be set or reset by instructions; 
however, only those instructions that do not 
affect the flags as an outcome of the execution 
should be used (e.g.. Load Immediate). 



The Sign flag stores the value of the most signif- 
icant bit of a result following arithmetic, logi- 
cal. Rotate, or Shift operations. 

When performing arithmetic operations on signed 
numbers, binary two's complement notation is used 
to represent and process information. A positive 
number is identified by a in the most signifi- 
cant bit position, and therefore, the Sign flag is 
also 0. 

A negative number is identified by a 1 in the most 
significant bit position, and therefore, the Sign 
flag is alsb 1 . 

RETI changes the value of the Zero flag when the 
saved Flag register is restored. 
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5.2.4 Overflow Flag (Y) 

For signed arithmetic, Rotate, and Shift opera- 
tions, the Overflow flag is set, to 1 when the 
result is greater than the maximum possible number 
( > 127) or less than the minimum possible number 
( < -128) that can be represented in two's comple- 
ment form. The flag is set to if no overflow 
occurs. 



encoded in a 4-bit field called the condition code 
(CC), which forms bits 4-7 of the conditional 
instructions. 

Section 5.4.2 lists the condition codes and the 
flag settings they represent. 



3.4 NOTATION AND BINARY ENCODING 



Following logical operations, the Overflow flag is 
set to 0. 

RETI changes the value of the Overflow flag when 
the saved Flag register is restored. 



In the detailed instruction descriptions that make 
up the rest of this chapter, operands and status 
flags are represented by a notational shorthand. 
Operands (condition codes and address modes) and 
their notations are as follows: 



5.2.5 Deciaal-Adjust Flag (D) 

The Decimal-adjust flag is used for BCD arith- 
metic. Since the algorithm for correcting BCD 
operations is different for addition and subtrac- 
tion, this flag specifies what type of instruction 
was last executed so that the subsequent Decimal 
Adjust (DA) operation can function properly. Nor- 
mally, the Decimal-adjust flag cannot be used as a 
test condition. 



Notation Address Mode Actual Operand/Range 

CC Condition Code See condition code 
list below 

r Working register Rn: where n = 0-15 
only 

R Register or reg: where reg repre- 
working register sents a number in the 
range 0-127, 240-255 



After a subtraction, the Decimal-adjust flag is 
set to 1 ; following an addition it is cleared to 
0. 

RETI changes the value of the Decimal-adjust flag 
when the saved Flag register is restored. 



Rn: where n = 0-15 

RR Register pair or reg: where reg repre- 
working register sents an even number 
pair in the range 0-126, 

240-254 



5.2.6 Half-Carry Flag (H) 



RRp: where p = 0, 
2,. ..,14 



TheJHalf-carry flag is set to 1 whenever an, addi- 
tion generates a carry out of bit 3 (Overflow), or 
a subtraction generates a borrow into bit 3. The 
Half-carry flag is used by the Decimal Adjust (DA) 
instruction to convert the binary result of a pre- 
vious addition or subtraction into the correct 
decimal (BCD) result. As in the case of the 
Decimal-adjust flag, the user does not normally 
access this flag. 



Ir Indirect working (i Rn: where n = 0-15 
register only 

IR Indirect register d reg: where reg re- 
or working " presents a number in 
register the range 0-127, 
240-255 

@ Rn: where n = 0-15 



RETI changes the value of the Half-carry flag when 
the saved Flag register is restored. 



Irr Indirect working @ RRp: where p = 0, 
register pair 2,..., 14 
only 



5.3 CONDITION CODES 

Flags C, Z, S, and V control the operation of the 
"conditional" Jump instructions. Sixteen fre- 
quently useful functions of the flag settings are 



IRR Indirect register ® reg: where reg re- 
pair or working sents an even number 
register pair in the range 0-126, 
240-254 

@ RRp: where p = 0, 
2,. ..,14 
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Notation Address Mode 

X Indexed 



DA 



RA 



Direct Address 



Relative Address 



IM 



Immediate 



Actual Operand/Range 

reg (Rn): where reg 
represent a number in 
the range 0-127, 
240-255 and n = 0-15 

addrs: where addrs 
represents a number 
in the range 0-65,535 

addrs: where addrs 
represents a number 
in the range +127, 
-128 which is an 
offset relative to 
the address of the 
next instruction 

#data: where data is 
a number between 
and 255 



3.4.1 Assenbly Language Syntax 

For proper instruction execution, Z8 PLZ/ASM 
assembly language syntax requires thgt "dst, src" 
be specified, in that order. The following 
instruction descriptions show the format of the 
object code produced by the assembler. This binary 
format should be followed by users who prefer 
manual program coding or who intend to implement 
their own assembler. 

Example: If the contents of registers ?o43 and ?o08 
are added and the result stored in %43, the 
assembly syntax and resulting object code are: 



ASM: 
OBJ: 



ADD 
04 



?i43, ?508 (ADD dst, src) 
08 43 (OPC src, dst) 



Additional symbols used are: 



In general, whenever an instruction format 
requires an 8-bit register address, that address 
can specify any register location in the range 
0-127, 240-255 or a working register R0-R15. If, 
in the above example, register ?o08 is a working 
register, the assembly syntax and resulting object 
code would be: 



Symbol 

dst 



SP 

PC 

FLAGS 

RP 

IMR 

# 



OPC 



Meaning 

Destination operand 
Source operand 
Indirect address prefix 

Stack Pointer 
Program Counter 
Flag register (R252) 
Register Pointer (R253) 
Interrupt mask register (251) 
Immediate operand prefix 

Hexadecimal number prefix 
Opcode 



ASM: 


ADD 


?^43, 


R8 


(ADD dst src) 


OBJ: 


04 


E8 


43 


(OPC src dst) 



For a more complete description of assembler syn- 
tax refer to the Z8 PLZ/ASM Assembly Language 
Manual (publication no. 03-3023-03) and ZSCAN 8 
User's Tutorial (publication no. 03-8200-01). 



3.4.2 Condition Codes and Flag Settings 

The condition codes and flag settings are sum- 
marized in the following tables. Notation for, the 
flags and how they are affected are as follows: 



Assignment of a value is indicated by the symbol 
"<-". For example, 

dst <- dst 4- src 

indicates that the source data is added to the 
destination data and the result is stored in the 
destination location. The notation "addr(n)" is 
used to refer to bit "n" of a given location. For 
example. 



c 


Carry flag 







Cleared to 


z 


Zero flag 




1 


Set to 1 


s 


Sign flag 




* 


Set or cleared 
according to 


V 


Overflow fJ 


.ag 




operation 


D 


Decimal-adjust flag 


■ - 


Unaffected 


H 


Half-carry 


flag 


X 


Undefined 



dst (7) 



refers to bit 7 of the destination operand. 
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Binary 


NneMonic 


Meaning 


Flags Settings 


0000 


F 


Always false 




_ 


1000 


(blank) 


Always true 




- 


0111 


C 


Carry 




C = 1 


1111 


NC 


No carry 




C = 


0110 


Z 


Zero 




Z = 1 


1110 


NZ 


Not 




Z = 


1101 


PL 


Plus 




S = 


0101 


MI 


Minus 




S = 1 


0100 


OY 


Overflow 




V = i 


1100 


NOV 


No overflow 




V = 


0110 


EQ 


Equal 




Z = 1 


1110 


NE 


Not equal 




Z = 


1001 


GE 


Greater than or 
equal 




(S XOR V) = 


0001 


LT 


Less than 




(S XOR V) = 1 


1010. 


GT 


Greater Than 




(Z OR (S XOR V))=0 


0010 


LE 


Less than or equal 




(Z OR (S XOR V))=1 


1111 


UGE 


Unsigned greater than 


C = 






or equal 






0111 


ULT 


Unsigned less than 




C =1 


1011 


UGT 


Unsigned greater than 


(C=0 AND Z=0) = 1 


0011 


ULE 


Unsigned less than 
equal 


or 


(C OR Z) = 1 
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Instruction AddrModo Opcode Flags Affected 
dst src (Hex) C Z S V D H 



Instruction 



ADC dst,src 
dst *- dst + src + 


^C 


(Note 1) 


ID 


* * * * * 


ADD dst, src 
dst — dst + src 




(Note 


1) 


on 


* * * * * 


AND dst,src 

dst - dst AND src 


(Note 


1) 


5D 


- * * - - 


CALL dst 

SP - SP - 2 
@SP - PC; PC * 


DA 
IRR 
-dst 




D6 
D4 




CCF 

C - NOT C 








EF 


*_____ 


CLR dst 

dst-0 




R 

m 




BO 

Bl 




COM dst 

dst - NOT dst 




R 
IR 




60 

61 


- * * - - 


CP dst,src 
dst - src 




(Note 1) 


AD 


****-- 


DA dst 

dst - DA dst 




R 
IR 




40 
41 


* * * X - - 


DEC dst 

dst - dst - 1 




R 
IR 




00 
01 


— * * * 


DECW dst 

dst - dst - 1 




RR 
IR 




80 
81 


— * * * ■ 


DI 

IMR (7) - 








8F 





DINZ r,dst 
r-r- 1 
if r =ft 

PC - PC + dst 
Range: +127, -128 



RA 



EI 

IMR (7) - 1 



rA 
r = 0-F 

9F 



INC dst 

dst - dst + 1 



R 
IR 



rE 

= 0-F 
20 
21 



mew dst RR 

dst *- dst + 1 IR 



AO 
Al 



IRET , BF 

FLAGS -@SP; SP - SP + 1 

PC - @SP; SP - SP + 2; IMR (7) - 1 



IP ccdst 




DA 




cD 


if cc is true 








c = 0-F 


PC ^ dst 




IRR 
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JR cc,dst 




RA 




cB 


if cc is true. 








c = 0-F 


PC - PC + 


dst 








Range: + 127, 


-128 








LD dst, src 




r 


IM 


rC 


dst — src 




r 


R 


- r8 






R 


r 


r9 
r = 0-F 






r 


X 


C7 






X 


r 


D7 






r 


Ir 


E3 






Ir 


r 


F3 






R 


R 


E4 






R 


IR 


E5 






R 


IM 


E6 






IR 


IM 


E7 






IR 


R 


F5 


LDC dst,src 




r 


Irr 


C2 


dst — src 




Irr 


r 


D2 


LDCI dst, src 




Ir 


Irr 


03 


dst ^ src 




Irr 


Ir 


D3 


r — r + 1 ; rr • 


-rr,+ 


1 







and Operation ^^ ^^^ 



AddrMode Opcode Flags Affected 

Byte 

(Hex) C Z S V D H 



LDE dst,src , r 
dst — src Irr 


Irr 
r 


82 
92 




LDEI dst, src Ir 
dst — src Irr 
r — r + 1 ; rr — rr + 1 


Irr 
Ir 


83 
93 




NOP 




FF 




OR dst,src (Note 1) 
dst - dst OR src 


4n 


_ * * - - 


POP dst R 

dst - @SP IR 
SP - SP + 1 




50 
51 




PUSH src 

SP-SP-1; @SP-src 


R 
IR 


70 
71 




RCF 

C^O 




CF 





RET 

PC-@SP; SP^SP + 2 




AF 








90 
91 




«^^^^ mi^z^J^R 








10 
11 




RLCdstL^j^^_^ R 








EO 
El 




^''^'' LHtn^fR 








CO 
01 




R«Cdst^^^^_^^^_^R 




SBC dst, src (Note 
dst ^ dst - src - C 


>1) 


3n 


* * * * 1 * 


SCF 

C^ 1 




DF 


1 






DO 
Dl 




SRA dst Lm .JTT-TiJ H 


* * * - - 


SRP src 

RP - src ■ 


Ini., 
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SUB dst, src (Note 
dst — dst - src 


'D 


2D 


****!* 


SWAP dst , ♦ , 1 , R 

' iJLi ' IR 




FO 
Fl 


X * * X - - 


TCM dst,src (Note 1) 
(NOT dst) AND src 


6D 


- * * - - 


TM dst, src (Note 1) 
dst AND src 


7D 


_ * * - - 


XOR dst,src (Note 1) 
dst - dst XOR src 


BD 


,- * * - - 



Note 1 

These instructions have an' identical set of addressing 
modes, which are encoded for brevity. The first opcode 
nibble is found in the instruction set table above. The 
second nibble is expressed symbolically by a L . in this 
table, and its value is found in the following table to the 
left of the applicable addressing mode pair. 

For example, to determine the opcode of an ADC 
mstructipn using the addressing modes r (destination) and 
Ir (source) is 13. 

Lower 
Opcode Nibble 



R 


R 


R 


IR 


R 


IM 


IR 


IM 
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5.6 Z8 
Instruction 
Descriptions 
and Formats 



ADC 

Add With Cany 



ADC dst^src 
Instruction Fon»t: 



OPC 



OPC 



OPC 



dst 


src 



dst 



dst 



Cycles 


OPC 
(Hex) 


Adclrees Node 
dst src 


6 


12 
13 


r 
r 


Ir 


10 


14 
15 


R 
R 


IR 


10 


16 
17 


R 
IR 


IM 
IM 



Operstion: 



dst < — dst + src + c 

The source opersnd, slong with the setting of the C flag, is added to the destination 
operand and the sum is stored in the destination. The contents of the source are not 
affected. Two's complement addition is performed. In multiple precision arithmetic, 
this instruction permits the carr^ from the addition of low-order operands to be 
carried into the addition of high-order operands. 



Flags: 



C: Set if there is a carry from the most-significant bit of the result; cleared 

otherwise 
Z: Set if the result is zero; cleared otherwise 
S: Set if the result is negative; cleared otherwise 
V: Set if arithmetic overflow occurs, that is, if both operands are of the same sign 

and the result is of the opposite sign; cleared otherwise 
D: Always cleared 
H: Set if there is a carry from the most-significant bit of the low-order four bits 

of the result; cleared otherwise 



Example: 



If the register named SUM contains 5516, the C flag is set to 1, working register 10 
contains Sb20 (32 decimal), and register 32 contains %^Q, the statement 



ADC SUM,aR10 

leaves the value 5b27 in Register SUM. 
cleared. , 



The C, Z, S, V, D, and H flags are all 



Note: 



When used to specify a 4-bit working-register address, address modes R or IR use the 
format : 



E 


src/dst 
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ADD 

Add 



ADD dstfSrc 
Instruction Foraat: 



OPC 



OPC 



OPC 



dst 


src 



dst 



dst 



Cycles 


OPC 
(Hex) 


Address Node 
dst arc 


6 


02 
03 


r - 
r 


r 
Ir 


10 


04 
05 


R 
R 


R 
IR 


10 


06 
07 


R 
IR 


IM 
IM 



Operation: 



dst < — dst + src 

The source operand is added to the destination operand and the sum is stored in the 
destination. The contents of the source are not affected. Two's complement addition 
is performed. 



Flags: 



C: Set if there was a carry from the most-significant bit of the result; cleared 

otherwise 
Z: Set if the result is zero; cleared otherwise 
V: Set if arithmetic overflow occurs, that is, if both operands are of the same sign 

and the result is of the opposite sign; cleared otherwise 
S: Set if the result is negative; cleared otherwise 
H: Set if a carry from the low-order nibble occurs 
D: Always reset to 



Example: 



If the register named SUM contains Sb44 and the register named AUGEND contains Sd11, 
the statement 

ADD SUM, AUGEND 

leaves the value %55 in register SUM and leaves all flags cleared. 



Note: 



When used to specify a 4-bit working-register address, address modes R or IR use the 
format: 



E 


src/dst 
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AND 

Logical 



AND dst^src 
Instruction ForMat: 



OPC 



OPC 



OPC 



dst 


src 



dst 



Cycles 


OPC 
(Hex) 


Address Mode 
dst src 


6 


52 
53 


r 
r 


r 
IR 


10 


54 
55 


R 
R 


R 
IR 


10 


56 
57 


R 
IR 


IM 
IM 



Operation: 



dst <— dst AND src 

The source operand is logically ANDed with the destination operand. The result is 
stored in the destination. The AND operation results in a 1 bit being stored 
whenever the corresponding bits in the two operands are both Is; otherwise a bit is 
stored. The contents of the source bit are not affected. 



Flags: 



C: Unaffected 

Z: Set if the result is zero; cleared otherwise 

V: Always reset to 

S: Set if the result bit 7 is set; cleared otherwise 

H: Unaffected 

D: Unaffected 



Example : 



If the source operand is the immediate value %1B (01111011) and the register named 
TARGET contains %C3 (11000011), the statement 



AND TARGET, #%7B 

leaves the value %43 (01000011) in register TARGET, 
cleared. 



The Z, V, and S flags are 



Note: 



When used to specify a 4-bit working-register address, address modes R or IR use the 
format: 



E 


src/dst 
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CALL 

Call Procedure 



CALL dst 



Instruction Fornat: 



OPC 



OPC 



dst 



OPC Address Mode 
Cycles (Hex) dst 



dst 



20 



20 



D6 

DA 



DA 
IRR 



Operation: 



SP <~ SP - 2 

isp <— PC 

PC <~ dst 

The current contents of the PC are pushed onto the top of the stack, The PC value 

is the address of the first instruction following the CALL instruction. The 

specified destinatiipn address is then loaded into the PC and points to the first 
instruction of a procedure. 

At the end of the procedure a RETurn instruction can be used to return to the 
original program flow. RET pops the top of the stack back into the PC. 



Flags: 



No flags affected; 



Example: 



If the contents of the PC are Sd1A47 and the contents of the SP (control registers 
254-5) are %3002, the statement 

CALL a;3521 

causes the SP to be decremented to %3000, Sb1A4A (the address following the 
instruction) is stored in external data memory Sb3000-Sb3001 , and the PC is loaded with 
Sb3521 . The PC now points to the address of the first statement in the procedure to 
be executed. 



Note: 



When used to specify a 4-bit working-register pair address, address mode IRR uses the 
format : 





dst 
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CCF 

Complement Carry Flag 



CCF 

Instruction Fomat: 



OPC 



Cycle 

6 



OPC 
(Hex) 

EF 



Operation: 



C <— NOT C 

The C flag is complemented; if C = 1, it is changed to C = 0, and vice-versa 



Flags: 



C: Complemented 

No other flags affected 



Cxanple: 



Tf the C flag contains a D, the statement 

CCF 
will change the to 1 . 
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CLR 

Clear 



CLR dst 
Instruction Fomat: 



OPC 



OPC Address Node 
Cycles (Hex) dst 



dst 



BO 
B1 



R 
IR 



(^ration: 



dst <— 

The destination location is cleared to 0. 



Flags: 



No flags affected. 



Exanple : 



If working register 6 contains SbAF, the statement 

CLR R6 
will leave the value in that register 



Note: 



When used to specify a 4-bit working-register address, address modes R or IR use the 
format: 



E 


dst 
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COM 

Complement 



COM dst 



Instruction Fornat: 



OPC 



Cycles 

6 



OPC Address Node 
(Hex) dst 



60 
61 



R 
IR 



Operation: dst <— NOT dst 

The contents of the destination location are complemented (one's complement); all 1 
bits are changed to 0, and vice-versa. 



Flags: 



C: Unaffected 

Z: Set if the result is zero; cleared otherwise 

V: Always reset to 

S: Set if result bit 7 is set; cleared otherwise 

H: Unaffected 

D: Unaffected 



Example : 



If working register 8 contains %24 (00100100), the statement 

COM R8 

leaves the value %DB (11011011) in that register. The Z and V flags are cleared and 
the S flag is set. 



Note: 



When used to specify a 4-bit working-register address, address modes R or IR use the 
format: 



E 


dst 
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Compare 



CP dst , src 
Instruction Format: 



OPC 



OPC 



OPC 



dst 


src 



dst 



dst 



Cycles 


OPC 
(Hex) 


Address Mode 
dst src 


6 


A2 
A3 


r 
r 


r 
Ir 


10 


A4 
A5 


R 
R 


R 
IR 


10 


A6 
A7 


R 
IR 


IM 
IM 



Operation: 



dst - src 

The source operand is compared to (subtracted from) the destination operand, and the 
appropriate flags set accordingly. The contents of both operands are unaffected by 
the comparison. 



Flags: 

/ 



C: Cleared if there is a carry from the most significant bit of the result; set 

otherwise, indicating a "borrow" 

Z: Set if the result is zero; cleared otherwise 

V: Set if arithmetic overflow occurs; cleare'd otherwise 

S: Set if the result is negative; cleared otherwise 

H: Unaffected 

D: Unaffected 



Example : 



If the register named TEST contains Sb63, working register contains Sd3G (48 
decimal), and register 48 contains %63, the statement 

CP TEST, @R0 

sets (only) the Z flag. If this statement is followed by "3P EQ, true_routine", the 
jump is taken. 



Note: 



When used to specify a 4-bit working-register address, address modes R or IR use the 
format: 



E 


src/dst 
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DA 

Decimal Adjust 



DA dst 
Instruction Fonrnt: 



OPC 



dst 



Cycles 

8 



OPC 
(Ifex) 

AO 
41 



Address 
dst 



R 
IR 



Operation: dst <— DA dst 

The destination operand is adjusted to form tw) 4-bit BCD digits following a binary 
addition or subtraction operation on BCD encoded bytes. For addition (ADD, ADC), or 
subtraction (SUB, SBC), the following table indicates the operation performed: 







Bits 4-7 




Bits 0-3 


Nuaber 






Carry 


Value 


H Flag 


Value 


Added 


Carry 


Instruction 


Before DA 


(Hex) 


Before DA 


(Hex) 


To Byte 


After DA 







0-9 





0-9 


00 










0-8 





A-F 


06 





ADD 





0-9 


1 


0-3 


06 





ADC 





A-F 





0-9 


60 


1 







9-F 





A-F 


66 


1 







A-F 


1 


0-3 


66 


1 




1 


0-2 





0-9 


60 


1 




1 


0-2 





A-F 


66 


1 




1 


0-3 


1 


0-3 


66 


1 


SUB 





0-9 





0-9 


00 





SBC 





0-8 


1 


6-F 


FA 







1 


7-F 





0-9 


AO ^ 


1 




1 


6-F 


1 


6-F 


9A 


1 



If the destination operand is not the result of a valid addition or subtraction of 
BCD digits, the operation is undefined. 



Flags: 



C: Set if there is a carry from the most significant bit; 

table above) 

Z: Set if the result is 0; cleared otherwise 

V: Undefined 

S: Set if the result bit 7 is set; cleared otherwise 

H: Unaffected 

D: Unaffected 



cleared otherwise (see 



333 



Cxanple: 



If addition is performed using the BCD values 15 and 27, the result should be 42. 
The sum is incorrect, however, when the binary representations are added in the 
destination location using standard binary arithmetic. 



Note: 



0001 0101 
+ 0010 0111 

xmrr jvsg = %3c 

The DA statement adjusts this result so that the correct BCD representation is. 
obtained. 

0011 1100 
+ 0000 0110 
TTTDU WTU = 42 

The C, Z, and S flags are cleared and V is undefined. 



When used to specify a 4-bit working-register address, address modes R or IR use the 
format : 



E 


dst 
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DEC 

Decreinent 



DEC d9t 
Instruction ForMat: 



OPC 



OPC Address 
Cyclers (Hex) dst 



dst 



00 
01 



R 
IR 



Operation: 



dst <— dst - 1 

The destination operand's contents are decremented by one. 



Flags: 



C: Unaffected 

Z: Set if the result is zero; cleared otherwise 

V: Set if arithmetic overflow occurred; cleared otherwise 

S: Set if the result is negative; cleared otherwise 

H: Unaffected 

D: Unaffected 



Exanple: 



If working register 10 contains 5»2A, the statement 

DEC R10 
leaves the value Sd29 in that register. The Z, V, and S flags are cleared. 



Note: 



When used to specify a 4-bit working-register address, address modes R or IR use the 
format : 



E 


dst 



335 



DECW 

Decrement Word 



DECN dst 



Instruction Fomat: 



OPC 



dst 



Cycles 



10 



OPC 
(Hex) 

80 
81 



Address 
dst 



RR 
IR 



Operation: 



dst <— dst - 1 

The contents of the destination location (which roust be an even address) and the 
operand following that location are treated as a single 16-bit value which is 
decremented by one. 



Flags: 



C: Unaffected 

Z: Set if the result is zero; cleared otherwise 

V; Set if arithmetic overflow occurred; cledred otherwise 

S: Set if the result is negative; cleared otherwise 

H: Unaffected 

D: Unaffected 



Example: 



If working register contains Sb30 (48 decimal) and registers 48-49 contain the value 
%FAF3, the statement 

DECW 3R0 

leaves the value %FAF2 in registers 48 and 49. The Z and V flags are cleared and S 
is set* 
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Dl 



Disable interrupts 

DI 

Instruction For«at: OPC 

Cycles (Hex) 



OPC 



Operation: IMR (7) <— 

Bit 7 of control register 251 (the Interrupt Mask Register) is reset tg 0. All 
interrupts are disabled, although they remain potentially enabled (i.e., the Global 
Interrupt Enable is cleared — not the individual interrupt level enables.) 

Flags: No flags affected 

Exanple: If control register 251 contains JIS8A (10001010, that is, interrupts IRQ1 and IRQ3 are 

enabled), the statement 

DI 

sets control register 251 to 5dOA and disables these interrupts. 
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DJNZ 

Decrement and Jump if Nonzero 



D3NZ r,dst 
Instruction Format: 



r 


OPC 



dst 



Cycles 

12 if jump taken 

10 if jump not taken 



OPC 
(Hex) 


Address Mode 
dst 


rA 


RA 


r=0 to F 





Operation: 



r <— r - 1 

If r ?f 0, PC <— PC + dst 

The working register being used as a counter is decremented. If the contents of the 
register are not zero after decrementing, the relative address is added to the 
Program Counter (PC) and control passes to the statement whose address is now in the 
PC. The range of the relative address is +127, -128, and the original value of the 
PC is the address of the instruction byte following the DONZ statement. When the 
working register counter reaches zero, control falls through to the statement 
following D3NZ. 



Flags: 



No flags affected 



Example: 



D3NZ is typically used to control a "loop" of instructions. In this example, 12 
bytes are moved from one buffer area in the register file to another. The steps 
involved are: 

o Load 12 into the counter (working register 6) 
o Set up the loop to perform the moves 
End the loop with D3NZ 



LD R6, #12 
LOOP: LD R9,0LDBUF (R6) 
LD NEWBUr (R6),R9 
D3NZ R6,L00P 



!Load Counter! 

!Move one byte to! 

!New location! 

! Decrement and ! 

!Loop until counter = 0! 



Note: 



The working register being used as a counter must be one of the registers 04- 7F. 
Use of one of the I/O ports, control or peripheral registers will have undefined 
results. 
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El 

Enable Interrupts 



EI 



Instruction Foraat: 



OPC 



Cycle 

6 



OPC 

(Hex) 

9F 



Operation: IMR (7) <— 1 

Bit 7 of control register 251 (the Interrupt Mask Register) is set 10 to 1. This 
allows any potentially enabled interrupts to become enabled. 



Flags: 



No flags affected 



Exanple: 



If control register 251 contains !!SOA (00001010, that is, interrupts IRQ1 and IRQ3 
potentially enabled), the statement 

EI 

sets control register 251 to %B^ (10001010) and enables these interrupts. 
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INC 

Increment 



INC dst 
Instruction Format: 



dst 


OPC 



OPC 



dst 



Cycles 


OPC 
(Hex) 


Address Node 
dst 


6 


rE 
r=0 to F 


r 


6 


20 
21 


R 
IR 



Operation : 



dst <— dst + 1 

The destination operand's contents are incremented by one. 



Flags: 



C: Unaffected 

Z: Set if the result is zero; cleared otherwise 

V: Set if arithmetic overflow occurred; cleared otherwise 

S: Set if the result is negative; cleared otherwise 

H: Unaffected 

D: Unaffected 



Example; 



If working register 10 contains Sn2A, the statement 

INC RIO 
leaves the value %2B in that register. The Z, V, and S flags are cleared. 



Note: 



When used to specify a A-bit workingrregister address, address modes R or IR use the 
format: 



E 


dst 
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INCW 

Increment Word 



INCM dst 
Instruction Fomat: 



OPC 



dst 



Cycle 

10 



OPC 
(Hex) 

AO 
A1 



Address Hode 
dst 

RR 
IR 



Operation: dst < — dst 4-1 

The contents of the destinstion (which must be sn even address) and the byte 
following that location are treated as a single 16-bit value which is incremented by 



Flags: 



C: Unaffected 

Z: Set if the result is zero; cleared otherwise 

V: Set if arithmetic overflow occurred; cleared otherwise 

S: Set if the result is negative; cleared othierwise 

H: Unaffected 

D: Unaffected 



Example: 



If working-register pair 0-1 contains the value SBrAF3, the statement 

INCW RRO 

leaves the value SFAFA in working-register pair 0-1. The Z and V flags are cleared 
and S is set. 
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IRET 

Interrupt Return 



IRET 

Instruction Format: OPC 

Cycles (Hex) 



OPC 



16 BF 



Operation: FLAGS <— iSP 
SP <-. sp + 1 

PC <— esp 
SP <-_ SP + 2 
IMR (7) <— 1 



This instruction is issued at the end of an interrupt service routine. It restores 
the Flag register (control register 252) and the PC. It also reenables any 
interrupts that are potentially enabled. 

Flags: All flags are restored to original settings (before interrupt occurred). 
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CC,d8t 



JP 

Jump 



Instruction Foraat: 

Conditional 



cc 


OPC 


Unconditional 


OPC 



dst 



Cycles 


OPC 
(Hex) 


Address Mode 
dst 


12 if jump taken 

10 if jump not taken 


ccD 
cc=0 to F 


DA 


8 


30 


IRR 



Operation: 



If cc is true, PC <— dst 

A conditional jump transfers Program Control to the destination address if the 
condition specified by "cc" is true; otherwise, the instruction following the 3P 
instruction is executed. See Section 6.4 for a list of condition codes. 

The unconditional jump simply replaces the contents of the Program Counter with the 
contents of the specified register pair. Control then passes to the statement 
addressed by the PC, decremented by one. 



Flags: 



No flags affected 



Example: 



If the carry flag is set, the statement 

3P C,%1520 

replaces the contents of the Program Counter with 5o1520 and transfers control to that 
location. Had the carry flag not been set, control would have fallen through to the 
statement following the OP. 



Note: 



When used to specify a 4-bit working-register pair address, address mode IRR uses the 
format : 



E 

' _ 


dst 
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JR 

Jump Relative 



3R cc,dst 



Instruction Fomat: 



cc 


OPC 



dst 



Cycles 

12 If jump taken 

10 If jump not taken 



OPC 
(Hex) 


Address 1 
dst 


ccB 


RA 


cc=0 to F 





Operation: If cc is true, PC <— PC + dst 

If the condition specified by "cc" is true, the relative address is added to the 
PC and control passes to the statement whose address in now in the PC; otherwise, the 
instruction following the 3R instruction is executed. (See Section 5.3 for a list of 
condition codes). The range of the relative address is +127, -128, and the original 
value of the PC is taken to be the address of the first instruction byte following 
the OR statement. 



Flags: 
Exanple: 



No flags affected 



If the result of the last arithmetic operation executed is negative, the following 
four statements (which occupy a total of seven bytes) are skipped with the statement 

3R MI, $+9 

If the result is not negative, execution continues with the statement following the 
3R. A shqrt form of a jump to label LO is 

3R LO 

where LO must be within the allowed range. The condition code is "blank" in this 
case, and is assumed to be "always true." 
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LD dstysrc 
Instruction Foraat: 



dst 


OPC 



src 


OPC 



OPC 



OPC 



OPC 



OPC 



OPC 



OPC 



dst 



dst 


src 



dst 



dst 


X 



src 


X 



dst 



dst 



*In this instance only a full 8-bit register address can be used. 



LD 

Load 



OPC Address Mode 
Cycles (Hex) dst src 



6 
6 


rC 
r8 


r 

r 


IM 
R 


6 


r9 
r=0 to F 


R» 


r 


6 
6 


E3 
F3 


r 
Ir 


Ir 

r 


10 
10 


E4 
E5 


R 
R 


R 
IR 


10 
10 


E6 
E7 


R 
IR 


IM 
IM 



10 



F5 



10 C7 
10 D7 



IR 



Operation: 



dst < — src 

The contents of the source are loaded into the destination. The contents of the 
source are not affected. 



Flags: 



No flags affected 



Example: 



If working register contains SOB (11 decimal) and working register 10 contains Sd83, 
the statement 

LD 240(R0),R10 

will load the value %B3 into register 251 (240 + 11). Since this is the Interrupt 
Mask register, the Load statement has the effect of enabling IRQO and IRQ1. The 
contents of working register 10 are unaffected by the load. 



Note: 



When used to specify a 4-bit working-register address, address modes R or IR use the 
format : 



E 


src/dst 



345 



LDC 

Load Constant 



LDC dst,src 
Instruction Fomat: 



QPC 



OPC 



dst 


src 




src 


dst 



Cycle 

12 

12 



OPC 
(Hex) 

C2 



D2 



Address Node 
dst src 



Irr 



Irr 



Operstion: dst < — src 

This instruction is used to load a byte constant from program memory into a working 
register, or vice-versa. The address of the program memory location is specified by 
a working register pair. The contents of the source are not affected. 



Flsgs: 



No flags affected 



Example: 



If the working-register pair 6-7 contains Sb30A2 and program-memory location Sb30A2 
contains the value So22, the statement 



LDC R2, @RR6 

loads the value Sb22 into working register 2. 
unchanged by the load. 



The value of location Sb30A2 is 
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LDCI 

Load Constant Autoincrement 



LDCI dstjsrc 
Instruction Foraat: 



OPC 



OPC 



dst 


src 




src 


dst 



Cycle 

18 

18 



OPC Address Hode 
(Hex) dst src 



03 



D3 



Ir Irr 
Irr Ir 



Operation: 



dst < — src 
r < — r + 1 
rr < — rr + 1 

This instruction is used for block transfers of data between program memory and the 
register file. The address of the program-memory location is specified by a 
working-register pair, and the address of the register-file location is specified by 
a working register. The contents of the source location are loaded into the 
destination location. Both addresses are then incremented automatically. The 
contents of the source are not affected. 



Flags: 



No flags affected 



Example: 



If the working-register pair 6-7 contains Sb30A2 and program-memory locations Sd30A2 
and 5o30A3 contain 5o22BC, and if working register R2 contains 5520 (32 decimal), the 
statement 

LDCI @R2, iRR6 
loads the value Sb22 into register 32. A second 

LDCI @R2, @RR6 
loads the value SoBC into register 33. 
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LDE 

Load External Data 



LDE dst,8rc 
Instruction Format: 



OPC 



OPC 



dst 


src 




8 re 


dst 



Cycles 

12 

12 



OPC Address Node 
(Hex) dst src 



82 
92 



Irr 



Irr 



Operation: 



dst < — src 

Th:Ls instruction is used to load a byte from external data memory into a working 
register or vice-versa. The address of the external date-memory location is 
specified by a working-register pair. The contents of the source are not affected. 



Flags: 



No flags affected 



Exanple: 



If the working-register pair 6-7 contains 5S404A and working register 2 contains !o22, 
the statement 

LDE iRR6,R2 

loads the value SS22 into external data-memory location 5o404A. 
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LDEI 

Load External Data Autoincrement 



LDEI dst f src 
Instruction Fonuit: 



OPC 



OPC 



OPC Address Node 
Cycles (Hex) dst src 



dat 


src 




src 


dst 



18 



18 



83 



93 



Irr 



Irt Ir 



Operstion: 



dst < — src 
r < — r + 1 
rr < — rr + 1 

This instruction is used for block transfers of data between external data memory 
and the register file. The address of the external data-memory location is specified 
by a working-register pair, and the address of the register file location is 
specified by a working register. The contents of the source location are loaded into 
the destination location. Both addresses are then incremented automatically. The 
contents of the source are not affected. 



Flags: 



No flags affected 



Example: 



Note: 



If the working-register pair 6-7 contains ?b404A, working register 2 contains Sd22 (34 
decimal), and registers 34-35 contain SdABC3, the statement 

LDEI iRR6,iR2 

loads the value SoAB into external location Sb404A. A second 

LOEI @RR6,@R2 

loads the value 5oC3 into external location 5o404B. 

When used to specify a 4-bit working-register pair address, address modes RR or IR 
use the format: 



E 


dst 
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NOP 

NoOperation 



NOP 

Instruction Fonrat: OPC 

Cycles (Hex) 



OPC 



FF 



Operstion: No action is performed by this instruction. It is typically used for timing delays. 
Flags: No flags affected 
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OR 

Logical Or 



OR d8t,src 
Instruction For«at: 



OPC 



OPC 



OPC 



dst 


arc 



dst 



dst 



Cycle 

6 
6 

10 
10 

10 
10 



OPC 
(Hex) 

42 
43 

44 
45 

46 
47 



Address Mode 
dst src 



r 
Ir 



R 
IR 



R IM 
IR IM 



Operstion: 



dst <— dst OR src 

The source operand is logically ORed with the destination operand and the result is 
stored in the destination. The contents of the source are not affected. The OR 
operation results in a one bit being stored whenever either of the corresponding bits 
in the two operands is 1 ; otherwise a bit is stored. 



Flags: 



C: Unaffected 

Z: Set if result is zero; cleared otherwise 

V: Always reset to 

S: Set if the result bit 7 is set; cleared otherwise 

H: Unaffected 

D: Unaffected 



Example: 



If the source operand is the immediate value %7B (01111011) and the register named 
TARGET contains SJC3 (11000011), the statement 



OR TARGET, #5!S7B 

leaves the value %FB (11111011) in register TARGET, 
and S is set. 



The Z and V flags are cleared 



Note: 



When used to specify a 4-bit working-register address, address modes R and IR use the 
format : 



E 


src/dst 
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POP 

Pop 



POP dst 
Instructicm Fomat: 



OPC 



OPC Address Node 
Cycles (Hex) dst 



dst 



10 
10 



50 
51 



R 
IR 



Operation: 



dst <— iSP 
SP <-> SP -f 1 

The contents of the location addressed by the SP are loaded into the destination. 
The SP is then incremented automatically. 



Flags: 



No flags affected 



Example: 



If the SP (control registers 254-255) contains SjIOOO, external data-memory location 
J0IOOO contains 5o55, and working register 6 contains 5!b22 (34 decimal), the statement 

POP 8R6 

loads the value %55 into registet 34. After the POP operation, the SP contains 
%1001. 



Note: 



When used to specify a 4-bit working-register address, address modes R or IR use the 
format : 



E 


dst 
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PUSH src 



PUSH 

Push 



Instruction Foraat: 



OPC 



Cycles 



OPC 
(Hex) 



10 Internal stack 70 

12 External stack 

12 Internal stack 71 

14 External stack 



Address 
src 



IR 



Opsration: 



SP <— SP - 1 
aSP <— src 

The contents of the SP are decremented, then the contents of the source are loaded 
into the location addressed by the decremented SP, thus sdding s new element to the 
top of the stsck. 



Flags: 



No flags affected 



ExMDle: 



If the SP contains Sainoi, the statement 

PUSH FLAGS 

stores the contents of the register named FLAGS in location 5o1000. After the PUSH 
operation, the SP contains 581 000. 



Note: 



When used to specify a 4-bit working-register address, address modes R or IR use the 
format : 



£ 


src 
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RCF 

Res6t Carry Flag 



RCF 

Instruction Fomat; OPC 

Cycles (Hex) 



OPC 



CF 



Operation: C <— 

The C flag is reset to 0, regardless of its previous value. 



Flags: C: Reset to 

No other flags affected 
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RET 

Return 



RET 



Instruction Fornat: 



OPC 



OPfc 
Cycles (Hex) 



14 



AF 



Operation: 



PC <~ iSP 
SP <~ SP 



+ 2 



This instruction is normally used to return to the previously eicecuted procedure at 
the end of a procedure entered by a CALL instruction. The contents of the location 
addressed by the SP are popped into the PC. The next statement executed is that 
addressed by the new contents of the PC. 



Flags: 



No flags affected 



Exanple; 



If the PC contains ?S35B4, the SP contains 5S2000, external datannemory location 582000 
contains %^8, and location 552001 contains SbB5, then the statement 

RET 

leaves the value K2002 in the SP and the PC contains ?o18B5, the address of the next 
instruction. 
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RL 

Rotate Left 



RL dst 



Instruction Format: 



OPC 



dst 



QPC Address 
Cycles (Hex) dst 



90 

91 



R 
IR 



Operation: 



C <— dst(7) 

dst(O) <— d8t(7) 

dst(n + 1) <— dst(n) n = - 6 

The contents of the destination operand are rotated left one bit position. The 
initial value of bit 7 is moved to the bit position and also replaces the carry 
flag. 



[cjc 



Flags: 



C: Set if the bit rotated from the most significant bit position Mas 1j i.e., bit 7 

was 1 
Z: Set if the result is zero; cleared otherwise. 
V: Set if arithmetic overflow occurred; that is, if the sign of the destination 

changed during rotation; cleared otherwise. 
S: Set if the result bit 7 is set; cleared otherwise 
H: Unaffected 
D: Unaffected 



Cxanple: 



If the contents of the register named SHIFTER are 5.88 (10001000), the statement 

RL SHIFTER 

leaves the value %^^ (00010001) in that register. The C flag and V flags are set to 
1 and the Z flag is cleared. 



Note: 



When used to specify a A-bit working-register address, address modes R or IR use the 
format : \ 



E 


dst 
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RLC 

Rotate Left Through Carry 



RLC dst 
Instruction Foraat: 



OPC 



dst 



OPC Address 
Cycles (Hex) dst 



10 
11 



R 
IR 



Operation : 



dst (0) <— C 
C <— dst (7) 
dst(n + 1) <— dst(n) n = - 6 

The contents of the destination operand with the C flag are rotated left one bit 
position. The initial value of bit 7 replaces the C flag; the initial value of the C 
flag replaces bit 0. 



C C 



Flags: 



C: Set if the bit rotated from the most significant bit position was 1; i.e., bit 7 

was 1 
Z; Set if the result is zero; cleared otherwise 
V: Set if arithmetic overflow occurs, that is, if the sign of the destination 

changed during rotation; cleared otherwise 
S: Set if the result bit 7 is set; cleared otherwise 
H: Unaffected 
D: Unaffected 



Example: 



If the C flag is reset (to 0) and the register named SHIFTER contains 5li8F (10001111), 
the statement 

RLC SHIFTER 

sets the C flag and the V flag to 1 and SHIFTER contains %^E (00011110). 



Note: 



When used to specify a 4-bit working-register address, address modes R or IR use the 
format : 



- E 


dst 
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Fiotate l=tight 



m dst 

Instruction Fomat: 



OPC 



dst 



Cycle 

6 
6 



OPC 

(Hex) 

EO 
E1 



Address Hode 
dst 



R 
IR 



Opet>ation: 



C <— d8t(0) 

dst(7) <— dst(O) 

dst(n) <— dst(n + 1) n = - 6 

The contents of the destination operand are rotated right one bit position, 
initial value of bit is moved to bit 7 and also replaces the C flag. 



The 



Flags: 



7 

> 







C: Set if the bit rotated from the least significant bit position was 1; i.e., bit 

was 1 
Z: Set if the result is zero; cleared otherwise 
Y: Set if arithmetic overflow occurred, that is, if the sign of the destination 

changed during rotation; cleared otherwise 
S: Set if the result bit 7 is set; cleared otherwise 
H: Unaffected 
D: Unaffected 



Example : 



If the contents of working register 6 are Sb31 (00110001), the statement 

RR R6 

sets the C flag to 1 and leaves the value Sb98 (10011000) in working register 6. 
Since bit 7 now equals 1 , the S flag and the V flag are also set . 



Note: 



When used to specify a 4-bit working-register address, address modes R or IR use the 
format : 



E 


dst 
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RRC 

Rotate Right Through Carry 



RRC dst 



Instruction Fomat: 



OPC 



dst 



Cycle 

6 
6 



OPC 
(Hex) 

CO 
C1 



Address 
dst 



R 
IR 



Operation: 



dst (7) <— C 
C <— dst(O) 
dstCn) <— dst(n + 1) n = - 6 

The contents of the destination operand with the C flag are rotated right one bit 
position. The initial value of bit replaces the C flag; the initial value of the 
C flag replaces bit 7. 



•> C 



Flags: 



C: Set if the bit rotated from the least significant bit position was 1; i.e., bit 

was 1 
Z: Set if the result is zero; cleared otherwise 
V: Set if arithmetic overflow occurred, that is, the sign of the destination changed 

during rotation; cleared otherwise 
S: Set if the result bit 7 is set; cleared otherwise 
H: Unaffected 
D: Unaffected 



Example: 



If the contents of the register named SHIFTER are 5SDD (11011101) and the Carry flag 
is reset to 0, the statement 

RRC SHIFTER 

sets the C flag and the V flag and leaves the value %6E (01101110) in the register. 



Note: 



When used to specify a 4-bit working-register address, address modes R or IR use the 
format : 



E 


dst 
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SBC 

Subtract With Cariy 



SBC dst,8rc 
Instruction Foraat: 



OPC 



OPC 



OPC 



dst 


src 




src 




dst 



dst 



Cycle 

6 
6 

10 
10 

10 
10 



OPC 
(Hex) 

32 
33 

34 
35 

36 
37 



Address Mode 
dst src 



R 
IR 



Ir 



R 
IR 



IM 
IM 



Operstion: 



dst < — dst - src - C 

The source operand, along with the setting of the C flag, is subtracted from the 
destination operand and the result is stored in the destination. The contents of the 
source are not affected. Subtraction is performed by adding the two's complement of 
the source operand to the destination operand. In multiple precision arithmetic, 
this instruction permits the carry ("borrow") from the subtraction of low-order 
operands to be subtracted from the subtraction of high-order operands. 



Flags: 



C: Cleared if there is a carry from the most significant bit of the result; set 

otherwise, indicating a "borrow" 
Zz Set if the result is 0; clisared otherwise 
V: Set if arithmetic overflow occurred, that is, if the operands were of opposite 

sign and the sign of the result is the same as the sign of the source; reset 

otherwise 
Ss Set if the result is negative; cleared otherwise 
H: Cleared if there is a carry from the most significant bit of the low-order four 

bits of the result; set otherwise indicating a "borrow." 
D: Always set to 1 



Example: 



If the register named MINUEND contains Sb16, the Carry flag is set to 1, working 
register 10 contains 5o20 (32 decimal), and register 32 contains 5o05, the statement 

SBC MINUEND, @R10 

leaves the value Sb10 in register MINUEND. The C, Z, V, S and H flags are cleared and 
D is set. 



Note: 



When used to specify a 4-bit working-register address, address modes R or IR use the 
format : ' 



E 


src/dst 
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SCF 

Set Carry Flag 



SCF 



Instruction Format; 



OPC 



Cycle 

6 



OPC 
(Hex) 

DF 



Operation; 



C <— 1 

The C flag is set to 1, regardless of its previous value. 



Flags: 



C: Set to 1 

No other flags affected 
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SRA 

Shift Right Arithmetic 



SRA dst 
Instruction Format: 



OPC 



dst 



Cycles 

6 
6 



OPC 

(Hex) 

DO 
D1 



Address 
dst 



R 
IR 



Operation: 



dst(7) <— dst(7) 

C <— dst(O) 

dst(n) <— dst(n +1) n = - 6 

An arithmetic shift right one bit position is performed on the destination operand. 
Bit replaces the C flag. Bit 7 (the Sign bit) is unchanged, and its value is also 
shifted into bit position 6. 



■Q 



J I 



Flags: 



C: Set if the bit shifted from the least significant bit position was 1; i.e., bit 

was 1 

Z: Set if the result is zero; cleared otherwise 

V: Always reset to 

S: Set if the result is negative; cleared otherwise 

H: Unaffected 

D: Unaffected 



Example: 



If the register named SHIFTER contains 5SBB (10111000), the statement 

SRA SHIFTER 

resets the C flag to and leaves the value SdDC (11011100) in register SHIFTER. The 
S flag is set to 1. 



Note: 



When used to specify a 4-bit working-register address, address modes R or IR use the 
format ; 



E 


dst 
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SRP 



Set Register Pointer 

SRP src 

Instruction Fomat: OPC Address Mode 

Cycles (Hbx) src 



OPC 



6 31 IM 



Operation: RP <~ src 



The specified value is loaded into bits 4-7 of the Register Pointer (RP) (control 
register 253). Bits 0-3 of the RP are alwayd set to 0. The source data (with bits 
0-3 forced to 0) is the starting address of a working-register group. The 
working-register group starting addresses are: 

Hex Decimal 



%00 





%10 


16 


s;20 


32 


%30 


48 


SSAO 


64 


%50 


80 


%60 


96 


SiTO 


112 



SbFO 240 (control and peripheral registers) 
Values in the range Sb80-E0 are invalid. 



Flags: No flags affected 



Example: Assume the RP currently addresses the control and peripheral register group and the 

program has just entered an interrupt service routine. The statement 

SRP mo 

saves the contents of the control and peripheral registers by setting the RP to %10 
(01110000), or 112 decimal. Any reference to working registers in the interrupt 
routine will point to registers 112-127. 
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SUB 

Subtract 



SUB dst , src 
Instruction Foniat: 



OPC 



OPC 



OPC 



dst 


src 



dst 



dst 



Cycle 

6 
6 

10 
10 

10 
10 



OPC 
(Hex) 

22 
23 

24 
25 

26 

27 



Address Mode 
dst src 



R 
IR 



R 
IR 



IM 
IM 



Operstion; 



dst < — dst - src 

The source operand is subtracted from the destination operand and the result is 
stored in the destination. The contents of the source are not affected. Subtraction 
is performed by adding the two's complement of the source operand to the destination 
operand. 



Flags: 



C; 



Z: 

V: 



Cleared if there is a carry from the most significant bit of the result; set 

otherwise, indicating a "borrow" 

Set if the result is zero; cleared otherwise 

Set if arithmetic overflow occurred, that is, if the operands were of opposite 

signs and the sign of the result is the same as the sign of the source operand; 

cleared otherwise 

Set if the result is negative; cleared otherwise 

Cleared if there is a carry from the most significant bit of the low-order four 

bits of the result;, set otherwise indicating a "borrow." 

Always set to 1 



Example: 



If the register named MINUEND contains Sb29, the statement 

SUB MINUEND, #%11 

will leave the value %^6 in the register. The C, Z, V, S and H flags are cleared and 
D is set. 



Note: 



When used to specify a 4-bit working-register address, address modes R or IR use the 
format : 



E 


src/dst 
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SWAP 

Swap Nibbles 



SWAP dst 
Instruction Foraat: 



OPC 



OPC 
Cycles (Hex) 



dst 



FO 
F1 



dst 



R 
IR 



Operation: 



dst(0 - 3) <— > dst(4 - 7) 

The contents of the lower four bits and upper four bits of the destination operand 
are swapped. 



7 ' 4 3 



Flags: 



C: Undefined 

Z: Set if the result is zero; cleared otherwise 

V: Undefined 

S: Set if the result bit 7 is set; cleared otherwise 

H: Unaffected 

D: Unaffected 



Example: 



Suppose the register named BCD__nperands contains 5KB3 (10110011). The statement 

SWAP BCD_Operands 
will leave the value Sb3B (00111011) in the register. The Z and S flags are cleared. 



Note: 



When used to specify a 4-bit working-register address, address modes R or IR use the 
format : 



E 


dst 
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TCM 

Test Complement Under Mask 



TCM dst,src 
Instruction Fomat: 



OPC 



OPC 



OPC 



dst 


arc 



dst 



dst 



'cles 


OPC 
(Hex) 


Address Node 
dst src 


6 
6 


62 
63 


r 
r 


r 
Ir 


10 
10 


64 
65 


R 
R 


R 
IR 


10 
10 


66 
67 


R 
IR 


IM 
IM 



Operation: 



(NOT dst) AND src 

This instruction tests selected bits in the destination operand for a logical "1" 
value. The bits to be tested are specified by setting a 1 bit in the corresponding 
position of the source operand (mask). The TCM statement complements the destination 
operand, which is then ANDed with the source mask. The Zero (Z) flag can then be 
checked to determine the result. When the TCM operation is complete, the destination 
location still contains its original value. 



Flags: 



C: Unaffected 

Z: Set if the result is zero; cleared otherwise 

V: Always reset to 

S: Set if the result, bit 7 is set; cleared otherwise 

H: Unaffected 

D: Unaffected 



Example: 



If the register named TESTER contains 5oF6 (11110110) and the register named MASK 
contains 5S06 (00000110), that is, bits 1 and 2 are being tested for a 1 value, the 
statement 

TCM TESTER, MASK 

complements TESTER (to 00001001) and then do a logical AND with register MASK, 
resulting in %00. A subsequent test of the Z flag, 

3P Z,plabel 

causes a transfer of program control. At the end of this sequence, TESTER still 
contains SdF6. 



Note: 



When used to specify a 4-bit working-register address, address modes R or IR use the 
format : 



E 


src/dst 
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TM 

Test Under Mask 



TM dst , src 
Instruction Foraat: 



OPC 



OPC 



OPC 



dst 


src 



dst 



dst 



Cycle 



OPC Address Mode 
(Hex) dst src 



6 


72 


r 


r 


6 


73 


r 


Ir 


10 


74 


R 


R 


10 


75 


R 


IR 


10 


76 


R 


IM 


10 


77 


IR 


IM 



Operation: 



dst AND src 

This instruction tests selected bits in the destination operand for a logical "0" 
value. The bits to be tested are specified by setting a 1 bit in the corresponding 
position of the source operand (mask), which is ANDed with the destination operand. 
The Z flag can be checked to determine the result. When the TM operation is 
complete, the destination location still contains its original value. 



Flags: 



C: Unaffected 

Z: Set if the result is zero; cleared otherwise 

V: Always reset to 

S: Set if the result bit 7 is set; cleared otherwise 

H: Unaffected 

D: Unaffected 



Example: 



If the register named TESTER contains %?6 (11110110) and the register named MASK 
contains 5o06 (00000110), that is, bits 1 and 2 are being tested for a value, the 
statement 

TM TESTER, MASK 

results in the value 5o06 (00000110). A subsequent test for nonzero 

DP NZ, plabel 

causes a transfer of program control. At the end of this sequence, TESTER still 
contains SbF6. The Z and S flags are cleared. 



Note: 



When used to specify a 4-bit working-register address, address modes R or IR use the 
format : 



E 


src/dst 
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XOR 

Logical Exclusive OR 



XOR dstySrq 
Instruction Foraat: 



OPC 



OPC 



OPC 



dst 


src 



dst 



dst 



Cycle 

6 
6 

10 
10 

10 
10 



OPC 
(Hex) 

B2 
B3 

B4 
B5 

B6 
B7 



Address Node 
dst src 



R 
IR 



R 
IR 



IM 
IM 



Operation: 



dst <— dst XOR src 

The source operand is logically EXCLUSIVE ORed with the destination operand and the 
result stored in the destination. Ttie EXCLUSIVE OR operation results in a one bit 
being stored whenever the corresponding bits in the operands are different; 
otherwise, a bit is stored. 



Flags: 



C: Unaffected 

Z: Set if the result is zero; cleared otherwise 

V: Always reset to 

S: Set if the result bit 7 is set; cleared otherwise 

H: Unaffected 

D: Unaffected 



Exanple: 



If the source operand is the irwnediate value Sb7B (011111011) and the register named 
TARGET contains SSC3 (11000011), the statement 

OR TARGET, #!S7B 

leaves the value SSBB (10111000) in the register. 



Note: 



When used to specify a 4-bit working-register address, address modes R or IR use the 
format : 



E 


src/dst 
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Chapter 6 
External Interlace 
(Z8601, Z8611) 



6.1 INTRODUCTiaN 

The ROM versions of the Z8 microcomputer have 40 
external pins, of which 32 are programmable I/O 
pins. The remaining 8 pins are used for power and 
control. Up to 16 I/O pins can be configured as 
an external memory interface. This interface 
function is the subject of this chapter. The I/O 
mode of these pins is described in Chapter 9. 



6.2 PIN DESCRIPTIONS 

^. Address Strobe (output, active LoMy 3-statey 

pin 9). Address Strobe is pulsed Low once at the 
beginning of each machine cycle. The rising edge 
of AS indicates that addresses, Read/Write (R/W), 
and Dgjta Memory (DM) signals, are valid when out- 
put for external program or data memory trans- 
fers. Under program control, AS can be placed in 



a high-impedance state along with Ports and 1 , 
Data Strobe (DS), and R/W. 

DSl Data Strobe (output, active Lom, 3>8tate, 

pin 8). Data Strobe provides the timing for data 
movement to or from Port 1 for each external 
memory transfer. During a Write cycle, data out 
is valid at the leading edge of DS. During a Read 
cycle, data in must be valid prior to the trailing 
edge of DS. DS can be placed in a high-impedance 
state along with Ports and 1 , AS, and R/W. 

R/W. Read/Write. (output, 3-statey pin 7). 

Read/Write determines the direction of data trans- 
fer for external memory transactions. R/W is Low 
when writing to external program or data memory, 
and High for all other transactions. R/W can be 
jalaced in a high-impedance state along with Ports 
and 1, AS, and DS. 
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Figure 6-2. Z8601/11 Pin Assignments 
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PO0-PO7, PI0-PI7, P2o~P27, P3o-P37. I/O port 
lines (inputs/outputs, TTL-compatible, pins 
12-40). These 32 I/O lines are divided into four 
8-bit I/O ports that can be configured under pro- 
gram control for I/O or external memory inter- 
face. Individual lines of a port are denoted by 
the seconc( digit of the port number. For example, 
P3q refers to bit of Port 3. Ports and 1 can 
be placed in a high-impedance state along with AS, 
DS, and R/5?. 



RESET. Reset (input, active Lou, pin 6). RESET 
initializes the Z8. When RESET is deactivated, 
program execution begins from internal program 
location 5oC* If held Low, RESET iacts as a regis- 
ter file protect during power-down and power-up 
sequences. RESET also enables the Z8 Test mode. 

XTAL1, XTAL2. Crystal 1, Crystal 2 (oscillator 
input and output, pins 3 and 2). These pins con- 
nect a parallel-resonant crystal (12 MHz maximum) 
or an external source (12 MHz maximum) to the 
on-board clock oscillator and buffer. 



6.3 CONFIGURING FOR EXTERNAL HENORY 

Before interfacing with external memory, the user 
must configute Ports and 1 appropriately. The 



minimum bus configuration uses Port 1 as a multi- 
plexed Address/Data port (ADg-ADy), allowing 
access to 256 bytes of external memory. In this 
configuration, the eight lower order address bits 
(Ag-Ay) are multiplexed with the data (Dg-Dy). 

Port can be programmed to provide four addi- 
tional address lines (Ag-Ai-)), which increases the 
externally addressaJDle program memory to AK 
bytes. Port can also be programmed to provide 
eight additional address lines (A3-A15), which 
increases the externally addressable memory to 62K 
bytes for the Z8601 or 60K bytes for the Z8611. 
Refer to Chapter 3, Figures 3-5 and 3-6, for 
external memory maps. 

Ports and 1 are configured for external memory 
operation by writing the appropriate bits in the 
Port 0-1 Mode register (Figure 6-3). 

For example. Port 1 can be defined as a multi- 
plexed Address/Data port (ADg-ADy) by setting D4 
to 1 and D3 to 0. The lower nibble of Port can 
be defined as address lines Ag-A>|i., by setting D1 
to 1. Similarly, setting D7 to 1 defines the upper 



nibble of Port as address lines A 



12-'^15* 



When- 



ever Port is configured jto output address lines 
Ai2'-Ai3, Ag-Ai>| must also be selected as address 
lines. 



R248P01IVI 
Port 0-1 Mode Register 

(% F8; Write Only) 



K 



PO4.PO7 MODE 
OUTPUT = 00 

INPUT = 01 " 
A12-A15 = IX 



Del ID4ID3I [DiIPqI 



t 



PO0-PO3 MODE 

00 = OUTPUT 

01 = INPUT 
1X = Aa-Aii 



PI0-PI7 MODE 
00 = BYTE OUTPUT 
- 01 = BYTE INPUT 

10 = AD0-AD7 

11 = HIGmMPEDANCE AD0-AD7, 

AS, DS, R7W, As-All, Ai2>Ai5 



Figure 6-3. Ports and 1 External Menory Operation 



370 



External Interface (Z8601 ,Z8611) 



Once Port 1 is configured as an Address/Data port, 
it can no longer be used as a register. Attempt- 
ing to read Port 1 returns FF; writing has no 
effect. Similarly, if Port is configured for 
address lines Ag-A-^5, it can no longer be used as 
a register. However, if only the lower nibble is 
defined as address lines Ag-A^i, the upper nibble 
is still addressable as an I/O register. Reading 
Port with only the lower nibble defined as 
address outputs returns XF, where X equals the 
data in bits D^-Dy. Writing to Port transfers 
data to the I/O, nibble only. 

An instruction to change the modes of Ports or 1 
should not be immediately followed by an instruc- 
tion that performs a stack operation, because this 
may cause indeterminate program flow. In addi- 
tion, after setting the modes of Ports and 1 for 
external memory, the next three bytes must be 
fetched from internal program memory. 



6.5 DATA ICHORY 

The two external memory spaces, data and program, 
can be addressed as a single memory space or as 
two separate spaces of equal size; i.e., 62K bytes 
each for the Z8601 and 60K bytes each for the 
Z8611. If the memory spaces are separated, 
program memory and data memory are logically 
selected by the Data Memory select output (DM). 
DM is available on Port 3, line 4 (P3^) by setting 
bits D^ and D^ in the Port 3 Mode register to 10 
or 01 (Figure 6-5). DM is active Low during the 
execution of the IDE, LDEI instructions. DM is 
also active during the execution of CALL, POP, 
PUSH, RET and IRET instructions if the stack 
resides in external memory. 



R247 P3M 
Port 3 Mode Register 

(% F7; Write Only) 



6.4 EXTERNAL STACKS 

Z8 architecture supports stack operations in 
either the register file or data memory. ' A 
stack's location is determined by bit D2 in the 
Port 0-1 Mode register. For example, if D2 is set 
to 1 , the stack is in^ internal data memory 
(Figure 6-4). 

R248P01M 
Port 0-1 Mode Register 

(% F8; Write Only) 



04 D3 



cni 



D2 



STACK SELECTION 
- = EXTERNAL 
1 = INTERNAL 



Figure 6-4. Ports and 1 Stack Selection 



The instruction used to change the stack selection 
bit should not be immediately followed by the 
instructions RET or IRET, because this will cause 
indeterminate program flow. 



P33 = INPUT P34 = OUTPUT 

1 P33 = INPUT P34 = 0M 

10 P33 = INPUT P34 = DM 

11 P33 = DAV1/RDY1 P34 = RDY1/DAV1 



Figure 6-5. Data Memory Operation 



6.6 BUS OPERATION 

The timing for typical data transfers between the 
Z8 and external memory is illustrated in Figure 
6-6. Machine cycles can vary from six to twelve 
clock periods depending on the operation being 
performed. The notations used to describe the 
basic timing periods of the Z8 are: machine cycles 
(Mn), timing states (Tn), and clock periods. All 
timing references are made with respect to the 
output signals AS and DS. The clock is shown for 
clarity only and does not have a specific timing 
relationship with other signals. 
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-MACHINE CYCLE - 



CLOCK 



PO 



PI 



AS 



m 



R/W 



DP 



X 



As-Ais 



X 



XZEZ>- 



■^Do-D7 INy 



\ 



/ 



\: 



/ 



X 



X 



-READ CYCLE - 



Figure 6«6a* External Instrudtion Fetch, or Nemory Read Cycle 



6.6.1 Address Strobe (AS) 

All transactions start with AS driven Low and then 
raised High by the ZB. The rising edge of AS 
indicates that R/W, DM, and the addresses output 
from Ports and 1 are valid. The addresses 
output via Port 1 remain valid only during MnTI 
and typically need to be latched using AS, whereas 
Port address outputs remain stable throughout 
the machine cycle. 



6.6.2 Data Strobe 

The Z8 uses DS to time the actual data transfer. 
For Write operations (R/W = Low), a Low on DS 
indicates that valid data is on the Port 1 ADq-AD-7 
lines. For Read operations, (R/W = High), the 
Address/Data bus is placed in a high-impedance 
state before driving DS Low so that the addressed 
device can put its data on the bus. The Z8 sam- 
ples this data prior to raising DS High* 



6.6.3 External Memory Operations 

Whenever the Z8 is configured for external memory 
operation, the addresses of all internal program 
memory references appear on the external bus. 
This should have no effect on the external system 
since the bus control lines, DS and R/W, remain in 
their inactive High state. DS and R/W become 
active only during external memory references. 

CAUTION 

Do not use LDC, LDCI, LDE or LDEI to 
write to internal program memory. The 
execution of these instructions causes 
the Z8 to assume that an external write 
operation is being performed and this 
will activate control signals DS and 
R/W. 
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Figure 6-6b. External Henory Mrite Cycle 



6.7 SHARED BUS 

Port 1 , along with AS, DS, R/W, and Port nibbles 
configured as address lines, can be placed in a 
high-impedance state, allowing the Z8601 or the 
Z8611 to share common resources with other bus 
masters. This shared bus mode is under software 
control and is programmed by setting Port 0-1 Mode 
register bits D^ and D3 both to 1 (Figure 6-7). 

Data transfers can be controlled by assigning, for 
example, P33 as a Bus Acknowledge input and P34 as 
a Bus Request output. Bus Request /Acknowledge 
control sequences must be software driven. 



R248 P01M 
Port 0-1 Mode Register 

{% F8; Write Only) 



PI0-PI7 MODE 
00 = BYTE OUTPUT 
- 01 = BYTE INPUT 

10 = AD0-AD7 

11 = HIGKHMPEDANCE AD0-AD7, 

AS, DS, R/W, As-All, A12-A15 



Figure 6-7. Shared Bus Operation 
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6.8 EXTENDED BUS TIMING 

The Z8601 land Z8611 can accommodate slow memory 
access times by automatically inserting an addi- 
tional state time (Tx) into the bus cycle. This 
stretches the DS timing by two clock periods, 
though internal memory access time is not 
affected. Timing is extended by setting bit D5 in 
the Port 0-1 Mode register to 1 (Figure 6-8). 

Figures 6-9a and 6-9b illustrate extended memory 
Read and Write cycles. 



R248P01M 
Port 0-1 Mode Register 

(% F8; Write Only) 



D5 



EXTERNAL MEMORY TIMING 
NORMAL ^ - 
* EXTENDED = 1 



•ALWAYS EXTENDED TIMING AFTER RESET EXCEPT Z8682 



Figure 6-8. Extended Bus lining 
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Figure 6-9a. Extended External Instruction Fetch, or Memory Read Cycle 
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6.9 INSTRUCTION TIHING 

The high throughput of the ZB is due, in part, to 
the use of instruction pipelining, in which the 
instruction fetch and execution cycles are over- 
lapped. During the execution of an instruction 
the opcode of the next instruction is fetched. 
This is illustrated in Figure 6-10. 

Figures 6-11 and 6-12 show typical instruction 
cycle timing for instructions fetched from exter- 
nal memory. (It should be noted that all instruc- 



tion fetch cycles have the same machine timing 
regardless of whether memory is internal or exter- 
nal.) For those instructions that require execu- 
tion time longer then that of the overlapped 
fetch, or instructions that reference program or 
data memory as part of their execution, the pipe 
must be flushed. In order to calculate the execu- 
tion time of a program, the internal clock periods 
shown in the cycles column of the instruction for- 
mats in Section 5.4 should be added together. The 
cycles are equal to one-half the crystal or input 
clock rate. 
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Figure 6>9b. Extended External Menory Write Cycle 
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Figure 6-10. Instruction Pipelining 
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Figure 6-12. Instruction Cycle Tiaing (Tmo and Three Byte Instructions) 
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6.10 RESET CONDITIONS 

After a hardware reset, Ports and 1 are con- 
figured as input ports, memory and stack are 



internal, extended timing is set and DM is 
inactive. Figure 6-13 shows the binary values 
reset into P01M. 
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•ALWAYS EXTENDED TIMING AFTER RESET EXCEPT 26^682 



Figure 6-13. Ports and 1 Reset 
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Chapter 7 
External Interface 
(Z8681, Z8682) 



7.1 INTRODUCTION 

The ROMless versions of the Z8 microcomputer have 
40 external pins, of which 24 are programmable I/O 
pins. Of the remaining 16 pins, 8 form an 
Address/Data bus and the others are used for power 
and control. Up to 8 I/O pins can be programmed 
as additional address lines to be used for 
external memory interface. 



7.2 PIN DESCRIPTIONS 



D^. Data Strobe (output, active Lom, pin 8). 

Data Strobe provides the timing for data movement 
to or from Port 1 for each memory transfer. 
During a Write cycle, data out is vailid at the 
leading edge of DS. During a Read cycle, data in 
must be valid prior to the trailing edge of DS. 

R/ff. Read/Write, (output, pin 7). Read/Write 
determines the direction of data transfer for 
memory transactions. R/W is Low when writing to 
program or data memory, and High for all other 
transactions. 



AS. Address Strobe (output, active Lom, pin 9). 

Address Strobe is pulsed Low once at the beginning 
of each machine cycle. The rising edge of AS 
indicates that addresses, Read/Write (R/W), and 
Data Memory (DM) signals are valid when output for 
program or data memory transfers. 



PO^-POy. Address/Data Port (inputs/outputs, TTL- 
compatible, pins 13-20). Port 1 is permanently 
configured as a multiplexed Address/Data memory 
interface. The lower eight address lines (Ag-Ay) 
are multiplexed with data (Dg-Dy), 
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HI0-PO7, P2o-P27, P3o-P37. I/O Port Lines 
CinfMits/outputSy TTL-conpatible). These 24 I/O 
lines are divided into 3 8-bit I/O ports that can 
be configured under program control for I/O or 
memory interface. Individual lines of a port are 
denoted by the second digit of the port number. 
For example, P3o refers to bit of Port 3. 



RESET. Reset (input, active Lom, pin 6). RESET 
initializes the . Z8681/82. When RESET is 
deactivated, program execution begins from 
external program location %C for the Z8681 and 
location 5S812 fpr the Z8682. If held Low, RESET 
acts as a register file protect during power-down 
and power-up sequences. 

XTAtI, XTAL2. Crystal 1, Crystal 2 (oscillator 
input and output, pins 3 and 2). These pins 
connect a parallel resonant crystal or an external 
source to the on-board clock oscillator and buf- 
fer. 



tion, the eight low order address bits (AQ-A7) are 
multiplexed with the data (DQ-D7). 

Port can be programmed to provide either four 
additional address lines (Ag-Aii) which increases 
the addressable memory to 4K bytes, or eight 
additional address lines (A8-A15) which increases 
the addressable memory to 64K bytes for the Z8681 
and 62K bytes for the Z8682. Refer to Chapter 3, 
Figures 3-5 and 3-6, for the memory maps. 

In the Z8681, Port lines intended for use as 
address lines are automatically configured as 
inputs after a Reset. These lines therefore float 
and their logic state remains unknown until an 
initialization routine configures Port 0. In the 
Z8682, Port lines are configured as address 
lines Ag-Ai5 following a Reset. 



7.3.1 Z8681 Initialization 



7.3 CONFIGURING PORT 

The minimum bus configuration uses Port 1 as a 
multiplexed Address/Data port (ADg-ADy) allowing^ 
access to 256 bytes of memory. In this configura- 



The initialization routine must reside within the 
first 256 bytes of executable code and must be 
physically mapped into memory by forcing the port 
address lines to a known state. Figures 7-3 and 
7-4 illustrate how a 4K byte memory space can be 
addressed. 
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AD0-AD7 



^ 



AS, DS, R/W 




As. 



A10. 



A11. 



PROGRAM 
MEMORY 
(4K BYTES) 



The initialization routine is mapped in tlie top 256 bytes of progrann nnemory. Depending on the 
application, the interrupt vectors nnay need to be written in the first 12 byte locations of program 
memory by the initialization routine. 



Figure 7-3. Example Z8681/Nenory Interface 



380 



P0RT1 



Z8681 

1/2 PORT 0^ 



t 



RESET- 



POo 



P01 
PO2 
PO3 



"T 



AD0-AD7 



A§, DS, R/W 



^ 
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The initialization routine is mapped in the first 256 bytes of program memory. Any memory write 
operation will cause the flip-flop to select Port outputs as addresses. 



Figure 7-4. Example Z8681/NeMiry Interface 



Port is programmed for memory operation by writ- 
ing the appropriate bits in the Port 0-1 Mode reg- 
ister (Figure 7-5). The proper port initializa- 
tion sequence is: 



The lower nibble of Port can be defined as 
address lines Ag-A^i, by setting D-^ to 1. 
Similarly, setting Dy to 1 defines the upper nib- 
ble of Port as address lines A12-A15. 



• Load Port with initial address value. 



• Configure Port 0-1 Mode register. 



Whenever Port is configured to output address 
lines A^2-A-|5, Ag-A-j^ must also be selected as 
address lines. 



Fetch the next three bytes without changing the 
address in Port 0. (This is necessary due to 
instruction pipelining.) 



R248P01M 
Port 0-1 Mode Register 

(% F8; Write Only) 



PO4-PO7 MODE 
OUTPUT = 00 
INPUT = 01 
A12-A15 = IX 



|o, 


"el 


jo. 


M 











PO0-PO3 MODE 

00 = OUTPUT 

01 = INPUT 
IX = Ap-Aii 



7.3.2 Z8682 Initialization 

The 28^82 must be operated in Test mode only. 
Section 8.4 gives a complete description of the 
proper technique for entering Test mode. 

The user initialization routine must begin at 
location 5o812 and must reside in memory fast 
enough for normal memory timing. In the Z8682, 
the user is not protected from reconfiguring 
Port 1 by writing to R248 (P01M). Therefore 
whenever a write is made to P01M, the value 10 
(binary) must be written to bits D^ and D3. Any 
other value will cause complete loss of program 
control. 



Figure 7-5. Z8681 Port Nenory Operation 
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The lower nibble of Port can be defined as 
addriess lines Ag-A^i, by setting D^ to 1. Simi- 
larly, setting Dy to 1 defines the upper nibble of 
Port as address lines A^2~^15» 

Whenever Port is configured to output address 
lines A12-A15, Ag'-A^i must also by selected as 
address lines. 



7.4 EXTERNAL STACKS 

The Z8681/82 architecture supports stack opera- 
tions in either the register file or data memory. 
A stack's location is determined by bit D2 in the 
Port 0-1 Mode register. For example, if D2 is set 
to 0, the stack is in external data memory 
(Figure 7-7). 



7,3.3 Read/Write Operations 

If Port is configured for address lines A7-A15, 
it can no longer be used as a register; however, 
if only the lower nibble of Port is defined as 
address lines Ag-Ai-j, the upper nibble is still 
addressable as an I/O register. When only the 
lower nibble is defined as address outputs, read- 
ing Port returns XF, where X equals the data in 
bits Di^-d-j, Writing to Port transfers data to 
the I/O nibble only. 



The instruction used to change the mode of Port 
should not be immediately followed by an instruc- 
tion that performs a stack operation, because this 
will cause indeterminate program flow. In addi- 
tion, after setting the mode of Port for memory, 
the . next three bytes must be fetched without 
changing the value of the upper byte of the Pro- 
gram Counter (PC). 



The instruction used to change the stack selection 
bit should not be immediately followed by the 
instructions RET or IRET, because this will cause 
indeterminate program flow. 



7.5 DATA rCMORY 

The two memory spaces, data and program, can be 
addressed as a single memory space or as two 
separate spaces of equal size; i.e. 64K bytes each 
for the Z8681 and 62K bytes each for the Z8682. 
If the memory spaces are separated, program memory 
and data memory are logically selected by Data 
Memory select output (DM). DM is made available 
on Port 3, line 4 (P3^) by setting bits D^ and D3 
in the Port 3 Mode register to 10 or 01 (Figure 
7-8). DM is active Low during the execution of 
the LDE, LDEI instructions. DM is also active Low 
during the execution of CALL, POP, PUSH, RET and 
IRET instructions if the stack resides in memory. 



R248P01M 
Port 0-1 Mode Register 

(% F8; Write Only) 



PO4-PO7 MODE 
OUTPUT = 00 
INPUT = 01 
A12-A15 = 1X 



D4 D3 



Di I Dp I 



t 



PO0-PO3 MODE 

00 = OUTPUT 

01 = INPUT 
1X = Ag-An 



PI0-PI7 MODE 
10 = AD0-AD7 



Figure 7-6. Z8682 Port Memory Operation 



382 



R248P01M 
Port 0-1 Mode Register 

(% F8; Write Only) 



D2 



STACK SELECTION 
- = EXTERNAL 
1 = INTERNAL 



7.6.1 Address Strobe (AS) 

All transactions start with AS driven Low and then 
raised High by the Z8681/82. The rising edge of 
AS indicates that R/W, DM (if used), and the 
addresses output from Ports and 1 are valid. 
The addresses output via Port 1 remain valid only 
during MnT1 and typically need to be latched using 
AS, whereas Port address outputs remain stable 
throughout the machine cycle. 



7.6.2 Data Strobe (DS) 



Figure 7-7. External Stack Operation 



R247 P3M 
Port 3 Mode Register 

(% F7; Write Only) 



D4 D3 



P33 = INPUT P34 = OUTPUT 

1 P33 = INPUT P34 = DM 

"10 P33 = INPUT P34 = DM 

11 P33 = DAV1/RDY1 P34 = RDY1/DAV1 



The Z8681/82 uses DS to time the actual data 
transfer. For Write operations (R/W = Low), a Low 
on DS indicates that valid data is on the Port 1 
ADQ-ADy lines. For Read operations (R/W = High), 
the Address/Data bus is placed in a high-impedance 
state before driving DS Low so that the addressed 
device can put its data on the bus. The Z8681/82 
samples this data prior to raising DS High. 



7.7 EXTENDED BUS TIMING 

The Z8681/82 accommodates slow memory access times 
by automatically inserting an additional software- 
controlled state time (Tx). This stretches the DS 
timing by two clock periods. Timing is extended 
by setting bit D5 in the Port 0-1 Mode register to 
1 (Figure 7-9). 



Figure 7-8. Port 3 Data Nenory Operation 



Refer to Section 6.7 for other figures pertaining 
to extended bus timing. 



7.6 BUS OPERATION 

Typical data transfers between the Z8681/82 and 
memory are illustrated in Figure 6-6. Machine 
cycles can vary from six to twelve clock periods 
depending on the operation being performed. The 
notations used to describe the basic timing 
periods of the Z8681/82 are: machine cycles (Mn), 
timing states (Tn), and clock periods. All timing 
references are made with respect to the output 
signals AS and DS. The clock is shown for clarity 
only and does not have a specific timing relation- 
ship with other signals. 



R248P01M 
Port 0-1 Mode Register 

(% F8; Write Only) 



D5 



EXTERNAL MEMORY TIMING 
NORMAL = - 
*EXTENDED = 1 



•ALWAYS EXTENDED TIMING AFTER RESET EXCEPT Z8682 



Figure 7-9. Extended Bus Timing 
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7.8 INSTRUCTION TIMING 



7.9 Z8681 RESET CONDITIONS 



The high throughput of the Z8681/82 is due, in 
part, to the use of instruction pipelining, in 
which the instruction fetch and execution cycles 
are overlapped. During the execution of the cur- 
rent instruction the opcode of the next instruc- 
tion is fetched as illustrated in Figure 6-10. 



After a hardware reset, Port is configured as 
input port, extended timing is set to accommodate 
slow memory access during the configuration 
routine, DM is inactive, and the stack resides in 
the register file. Figure 7-10 shows the binary 
values reset into P01M. 



Figures 6-11 and 6-12 show typical instruction 
cycle timing for instructions fetched from mem- 
ory. For those instructions that require execu- 
tion time longer than that of the overlapped 
fetch, or reference program or data memory as part 
of their execution, the pipe must be flushed. In 
order to calculate the execution time of a pro- 
gram, the internal clock periods shown in the 
cycles column of the instruction formats in Sec- 
tion 5.6 should be added together. The cycles are 
equal to one-half the crystal or input clock rate. 



7.10 Z8682 RESET CONDITIONS 

After a hardware reset. Port is configured as 
address lines Ag-A'j5, memory timing is normal, DM 
is inactive, and the stack resides in the register 
file. Figure 7-11 shows the binary values reset 
into P01M. 



R248P01M 
Port 0-1 Mode Register 

(% F8; Write Only) 



PO4-PO7 MODE 
OUTPUT = 00 

INPUT = 01 " 
A12-A15 = IX 

EXTERNAL MEMORY TIMING 
NORMAL = - 
* EXTENDED = 1 



PO0-PO3 MODE 

. 00 = OUTPUT 

01 = INPUT 

IX = Ag-Aii 

STACK SELECTION 
- = EXTERNAL 
1 = INTERNAL 



^ALWAYS EXTENDED TIMING AFTER RESET EXCEPT Z8682 



Figure 7-10. Z8681 Port and 1 Reset Conditions 



R248P01M 
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PO4-PO7 MODE 
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INPUT = 01 " 
A12-A15 = IX 
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Figure 7>11. Z8682 Ports and 1 Reset Conditions 
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Chapter 8 
Reset and Clock 



8.1 RESET 

This section describes Z8 reset conditions, reset 
timing, and register initialization procedures. 

A system reset overrides all other operating con- 
ditions and puts the Z8 into a known state. To 
initialize the chip's internal logic, the reset 
held Low for at least 18 clock 



input must 
periods. 



be 



While RESET is Low, AS is output at the internal 



clock rate (XTAL frequency divided by 2), DS is 
forced Low and R/W remains High. (Zilog Z-BUS com- 
patible peripherals use the AS and DS coincident 
Low state as a peripheral reset function.) In 
addition, interrupts are disabled, Ports 0, 1, and 
2 are put in input mode, and %C is loaded into the 
Program Counter. 

The hardware Reset initializes the control and 
peripheral registers, as shown in Table 8.1. 
Specific reset values are shown by 1s or Os, while 
bits whose states are unknown are indicated by the 



Table 8>1. Control and Peripheral Register Reset Values 



Register 



Dy Dg D5 D4 D3 D2 Di Dj, 



CoMMents 



SIFO Serial I/O 
S»F1 Timer Mode 

SbF2 Counter/Timer 1 

%F3 n Prescaler 



undefined 
00000000 



undefined 
uuuuuuOO 



Counter/Timers stopped 



Single Pass count mode, 
external clock source 



SJF4 Counter /Timer 
%F5 TO Prescaler 

%F6 Port 2 Mode 
%n Port 3 Mode 



5SF8 Port 0-1 Mode 
Z8601/Z8611 

%F8 Port 0-1 Mode 
Z8681 



%F8 Port 0-1 Mode 
Z8682 



undefined 
uuuuuuuO 



11111111 
OOOOOOuO 



€ 1 1 1 1 1 



1110 10 1 



10 10 110 



SoF9 Interrupt Priority undefined 

SoFA Interrupt Request 

SbFB Interrupt Mask 

%FC Flags 

%FD Register Pointer 

SiFE Stack Pointer 

%FF Stack Pointer 



uuOOOOOO 

Ouuuuuuu 

undefined 

undefined 

undefined 

undefined 



Single Pass count mode 

All lines input 

Port 2 open-drain 

P3o-P33 input; P34-P37 output 

Ports and 1 inputs; internal stack; 
extended external memory timing 

Port inputs 

Port 1 Address/Data; internal stack; 

extended external memory timing 

Port Address 

Port 1 Address/Data 

internal stack; normal external 

memory timing 

Reset all interrupt disabled 
Interrupts disabled 



Most significant byte 
Least significant byte 
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letter u. Registers that are not predictable are 
listed as undefined. 



Program execution starts four clock cycles after 
The initial instruction 
Figure 8-1 shows reset 



RESET has returned High, 
fetch is from location %Z. 
timing. 



After a reset, the first program executed should 
be a routine that initializes the control regis- 
ters to the required system configuration. The 
Interrupt Request register remains inactive until 
an EI instruction is executed. This guarantees 
that program execution can proceed free from 
interrupts. 



RESET is the input of a Schmitt trigger circuit. 
To form the internal reset line, the output of the 
trigger is synchronized with the internal clock 
(xtal frequency divided by 2). The clock must 
therefore be running for RESET to function. For a 
power-up reset operation, the RESET input must be 
held Low for at least 50 ms after the power supply 
is within tolerance. This allows the on-board 
clock oscillator to stabilize. An internal 
pull-up combined with an external capacitor of 
1 ®F provides enough time to properly reset the Z8 
(Figure 8-2). 



8.2 CLOCK 

The Z8 derives its timing from on-board clock 
circuitry connected to pins XTAL1 and XTAL2. The 
clock circuitry consists of an oscillator, a 
divide-by-2 shaping circuit, and a clock buffer. 
Figure 8-3 illustrates the clock circuitry. The 
oscillator's input is XTAL1 ; its output is XTAL2. 
The clock can be driven by a crystal, a ceramic 
resonator, or an external clock source. 

Crystals and ceramic resonators should have the 
following characteristics to ensure proper oscil- 
lator operation: 

Cut: AT (crystal only) 
Mode: Parallel, Fundamental 
Capacitance 30 pF nnax 
Resistance: 100 ohms max 

Depending on operation frequency, the oscillator 
may require the addition of capacitors CI and C2' 
(shown in Figure 8-4). The range of recommended 
capacitance values is dependent on crystal speci- 
fications but should not exceed 15 pF. The ratio 
of the values of C1 to C2 can be adjusted to shift 
the operating frequency of the circuit by approxi- 
mately ±.005%. 
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Figure 8-1. Reset Timing 
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Figure 8-2. Power-Up Reset Circuit 



When an external frequency source is used, it must 
drive both XTAL1 and XTAL2 inputs. This differen- 
tial drive requirement arises from the loading on 
the oscillator output (XTAL2) without the reactive 
feedback network of a crystal or resonator. A 
typical clock interface circuit is shown in Figure 
8-5. 

The capacitors shown represent the maximum para- 
sitic loading when using a 74LS04 driver. The 
pull-up resistors can be eliminated by using a 
74HC04 driver. 



osc 



BUFFER 



INTERNAL 
CLOCK 



Figure 8-3. Z8 Clock Circuit 
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Figure 8-4. Crystal/Ceramic Resonator Osc|.llator 
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Figure 8-5. External Clock Interface 



387 



Chapter 9 
I/O Ports 



9.1 INTRODUCTION 

The Z8 has 32 lines dedicated to input and out- 
put. These lines are grouped into four 8-bit 
ports and are configurable as input, output, or 
address/data. Under software control, the ports 
can be programmed to provide address/data, timing, 
status, serial, and parallel input/output with or 
without handshake. 

All ports have active pull-ups and pull-downs 
compatible with TTL loads. In addition, the 
pull-ups of Port 2 can be turned off for 
open-drain operation. 



9.1.1 Node Registers 

Each port has an associated mode register which 
determines the port's functions and allows dynamic 
change in port functions during program execu- 
tion. Ports and mode registers are mapped into 
the register file as shown in Figure 9-1 . 

Because of their close association, ports and mode 
registers are treated like any other general-pur- 
pose register. There are no special instructions 
for port manipulation; any instruction that 
addresses a register can address the ports. Data 
can be directly accessed in the port register, 
with no extra moves. 
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9.1.2 Input and Output Registers 

Each bit of Ports 0, 1, and 2 has an input regis- 
ter, an output register, associated buffer, and 
control logic. Since there are separate input and 
output registers associated with each port, writ- 
ing to bits defined as inputs stores the data in 
the output register. This data cannot be read as 
long as the bits are defined as inputs. However, 
if the bits are reconfigured as output, the data 
stored in the output register is reflected on the 
output pins and can then be read. This mechanism 
allows the user to initialize the outputs prior to 
driving their loads. 

Since port inputs are asynchronous to the ZB's 
internal clock, a Read operation could occur 
during an input transition. In this case, the 
logic level might be uncertain — somewhere between 
a logic 1 and 0. To eliminate this meta-stable 
condition, the ZB latches the input data two clock 
periods prior to the execution of the current 
instruction. The input register uses these two 
clock periods to stabilize to a legitimate logic 
level before the instruction reads the data. 



9.2 PORT 

This section deals only with the I/O operation of 
Port 0. Refer to Sections 6.2 and 7.2 for a 
description of the port's external memory inter- 
face operation. 

Port is a general I/O port. Bits within each 
nibble can be independently programmed as inputs, 
outputs or address lines. Figure 9-2 shows a 
block diagram of Port 0. This diagram also 
applies to Ports T and 2. 



Figure 9-1. I/O Port and Port Ncxie Registers 
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INPUT REGISTER 



INPUT BUFFER 




INTERNAL BUS 



OUTPUT REGISTER 



OUTPUT BUFFER 



Figure 9-2. Ports 0, 1, and 2 Block DiagraM 



I/O Ports 



9.2.1 Read/Write Operations 

In the nibble I/O mode, Port is accessed as gen- 
eral-purpose register PO (SoOO). The port is writ- 
ten by specifying PO as an instruction's destina- 
tion register. Writing the port causes data to be 
stored in the port's output register. 

The port is read by specifying PO as the source 
register of an instruction. When an output nibble 
is read, data on the external pins is retuyned. 
Under normal loading conditions this is equivalent 
to reading the output register. Reading a nibble 
defined as input also returns data on the external 
pins. However, input bits under handshake control 
return data latched into the input register via 
the input strobe. 

The Port 0-1 Mode register bits D^Dg and DyDg are 
used to configure Port nibbles (Figure 9-3). 
The lower nibble (POQ-PO3) can be defined as 
inputs by setting bits D-| to and Dq to 1 , or as 
outputs by setting both D-j and Dq to 0. Likewise, 
the upper nibble (PO^-POy) can be defined as 
inputs by setting bits Dy to and Dg to 1, or as 
outputs by setting both Dg and Dy to 0. 



R248P01M 
Port 0-1 Mode Register 

(% F8; Write Only) 



D7 D, 



PO4-PO7 MODE 
OUTPUT = 00 

INPUT = 01 " 
A12-A15 4^ IX 



Di|DoI 



PO0-PO3 MODE 

00 = OUTPUT 

01 = INPUT 
IX = Ae-Aii 



Figure 9-3. Port I/O Operation 



R247P3M 

Port 3 Mode Register 

(% F7; Write Only) 



n 



P32 = INPU T P35 = OUTPUT 

"1 P32 =DAV0/RDY0 PSs = RDYO/DAVO 



9.2.2 Handshake Operation 

When used as an I/O port, Port can be placed 
under handshake control by programming the Port 3 
Mode register bit D2 to 1 (Figure 9-4). In this 
configuration, handshake control lines are DAVq 
(P32) and RDYg (P35) when Port is an input port, 
or RDYq (P32) and DAVq (P35) when Port is an 
output port. 

Handshake direction is determined by the configu- 
ration (input or output) assigned to Port O's 
upper nibble, PO^-POy. The lower nibble must have 
the same I/O configuration as the upper nibble to 
be under handshake control. Figure 9-5 illus- 
trates the Port upper and lower nibbles, and the 
associated handshake lines of Port 3. 



Figure 9-4. Port Handshake Operation 






PO4-PO7 I PORTO 
PO0-PO3 Ml/O OR A8-A15) 



. HANDSHAKE CONTROLS 
> DAVo AND RDYo 
' (P32 AND PSs) 



Figure 9-5. Port 



Handshake operation is discussed in detail in Sec- 
tion 9.6. 
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9.3 PORT 1 



9.3.2 Handshake Operations 



This section deals only with the I/O operation of 
Port 1 and does not apply to the Z8681/82 ROMless 
devices. Refer to Sections 6.2 and 7.2 for a 
description of the port's external memory inter- 
face operation. 

Port 1 is a general-purpose I/O port that can be 
programmed as a byte I/O port with or without 
handshake, or as an address/data port for inter- 
facing with external memory. Refer to Figure 9-2 
for a block diagram of Port 1 . 



When used as an I/O port, Port 1 can be placed 
under handshake control by programming the Port 3 
Mode register bits D^ and D3 both to 1 (Figure 
9-7). In this configuration, handshake control 
lines are DAV>| (P33) and RDY^ (P3^) when Port 1 is 
an input port, or RDY^ (P33) and DAV>| (P3^) when 
Port 1 is an output port. 



R247 P3M 
Port 3 Mode Register 

(% F7; Write Only) 



9.3.1 Read/Vfrite Operations 

In byte input or byte output mode, the port is 
accessed as general -purpose register P1 (5301). 
The port is written by specifying P1 as an 
instruction's destination register. Writing the 
port causes data to be stored in the port's output 
register. 

The port is read by specifying P1 as the source 
register of an instruction. When an output is 
read, data on the external pins is returned. 
Under normal loading conditions, this is equiva- 
lent to reading the output register. When Port 1 
is defined as an input, reading also returns data 
on the external pins. However, inputs under hand- 
shake control return data latched into the input 
register via the input strobe. 

Using the Port 0-1 Mode register, Port 1 is con- 
figured as an output port by setting bits D4 and 
D3 to Os, or as an input port by setting D^ to 
and D3 to 1 (Figure 9-6). 

R248P01M 
Port 0-1 Mode Register 

(% F8; Write Only) 



D4 D3 



1 



c 



D4 D; 



PI0-PI7 MODE 
00 = BYTE OUTPUT 
- 01 = BYTE INPUT 

10 = AD0-AD7 

11 = rnGmMPEDANCE AD0-AD7, 

AS, DS, R/W, A8-A11, Ai2>Ai5 



P33 = INPUT P34 = OUTPUT 

1 P33 = INPUT P34 = DM 

10 P33 = INPUT P34 = DM 

11 P33 = DAV1/RDY1 P34 = RDY1/DAV1 



Figure 9-7. Port 1 Handshake Operation 



Handshake direction is determined by the configu- 
ration (input or output) assigned to Port 1. For 
example, if Port 1 is an output port then hand- 
shake is defined as output. Figure 9-8 illus- 
trates the Port 1 lines and the associated hand- 
shake lines of Port 3. 

Handshake operation is discussed in detail in Sec- 
tion 9.6. 



\^ 



PORT 1 

(I/O OR AD0-AD7) PI0-PI7 






HAND SHAKE CONTROLS 
DAVi AND RDYi 
(P33 AND P34) 



Figure 9-8. Port 1 



Figure 9-6. Port 1 I/O Operation 
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9.4 PORT 2 



9.4.2 Handshake OpeFation 



Port 2 is a general -purpose port. Each of its 
lines can be independently programmed as input or 
output via the Port 2 Mode reigister (Figure 9-9). 
A bit set to a 1 in P2M configures the correspond- 
ing bit in Port 2 as an input, while a bit set to 
determines an output !|.ine. 



Port 2 can be placed under handshake control by 
programming the Port 3 Mode register (Figure 
9-10). In this configuratidn, Port 3 lines P3^ 
and P3g are used as the handshake control lines 
DAV2 and RDY2 for input handshake, or RDY2 and 
DAV2 for output handshake. 



R246 P2M 
Port 2 Mode Register 

(%F6; Write Only) 



R247 P3M 
Port 3 Mode Register 

(% F7; Write Only) 



Di D, 



L 



P20-P27 MODE 
- OUTPUT 
1 INPUT 



Figure 9-9. Port 2 I/O Operation 



9.4.1 Read/Write Operations 

Port 2 is accessed as general-purpose register P2 
(Sd02). The port is written by specifying P2 as an 
instruction's destination register. Writing the 
port causes data to be stored in the port's output 
register, and reflected externally on any bit con- 
figured as an output. 

The port is read by specifying P2 as the source 
register of an instruction. When an output bit is 
read, data on the external pin is returned. Under 
normal loading conditions, this is equivalent to 
reading the output register. However, if a bit of 
Port 2 is defined as an open-drain output, the 
data returned is the value forced on the output 
pin by the external system. This may not be the 
3 the data in the output register. 



Reading input bits of Port 2 also returns data on 
the external pins. However, inputs under hand- 
shake control return data latched into the input 
register via the input strobe. 



P3i = INPUT (Tin) P36 = OUTP UT (Tq ut) 
■ 1 P3i = DAV2/RDY2 PSe = RDY2/DAV2 



Figure 9-10. Port 3 Handshake Operation 



Handshake direction is determined by the configu- 
ration (input or output) assigned to bit 7 of Port 
2. Only those bits with the same configuration as 
P2-7 will be under handshake control. Figure 9-11 
illustrates Port 2's bit lines and the associated 
handshake lines of Port 3. 



P20 






2(1/0) 



P27 

HAND SHAKE CONTROLS 
DAV2 AND RDY2 
(P3i AND P36) 



Figure 9-11. Port 2 
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Port 2 can also by configured to provide open- 
drain outputs by programming Port 3 Mode register 
(P3M) bit Dg to (Figure 9-12). 

Regardless of the bit input/output configuration, 
Port 2 is always written and read as a byte-wide 
porti 



R247 P3M 
Port 3 Mode Register 

(% F7; Write Only) 



L 



PORT 2 PULL-UPS OPEN DRAIN 

1 PORT 2 PULL-UPS ACTIVE 



Figure 9-12. Port 2 Open-Drain Outputs 



9.5 PORT 3 

Port 3 differs structurally from the other three 
ports. Port 3 lines are fixed as four input 
(P3q-P33) and four output (P34-P37) and do not 
have an input and output register for each bit. 
Instead, all the input lines have one input' regis- 
ter, and output lines have an output register. 
Under software control, the lines can be con- 
figured as input or output, special control lines 
for handshake, or as I/O lines for the on-board 
serial and timer facilities. Figure 9-13 is a 
block diagram of Port 3, "^ 



9.5.1 Read/Write Operations 

Port 3 is accessed as general-purpose register P3 
(%03). The port is written by specifying P3 as an 
instruction's destination register. However, 



INPUT 
REGISTER 



READ 
PORT 




PORT 
INPUT 
LINES 
(P30-P33) 



TO INTERRUPT TIMER, HANDSHAKE LOGIC 
OR SERIAL I/O 



< 



READ 
PORT 



OUTPUT 

DATA 
RETURN 
BUFFER 



OUTPUT 
REGISTER 



^ 



WRITE 
PORT 



^ 



tl 



OUTPUT 
BUFFER 



^ 



^ 



PORT 

OUTPUT 

LINES 

(P34-P37) 



FROM TIMER, HANDSHAKE LOGIC 
OR SERIAL I/O 



INTERNAL 
BUS 



Figure 9-13. Port 3 Block Diagran 
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I/O Ports 



Port 3 outputs cannot be written if they are used 
for special functions. When writing to Port 3, 
data is stored in the output register. 

The port is read by specifying P3 gis the source 
register of an instruction. When reading from 
Port 3, the data returned is both the data on the 
input pins and in the output register. 



9.5.2 Special Functions 

Special functions for Port 3 are defined by pro- 
gramming the Port 3 Mode register. By writing Os 
in D2-Dg, lines P3g-P3y ar configured in input/ 
output pairs (Figure 9-14). Table 9-1 shows 
available functions for Port 3. The special 
functions indicated in the table are discussed in 
detail in their corresponding sections in this 
manual. 

Port 3 input lines P3o-P33 always function as 
interrupt requests regardless of the configuration 
specified in the Port 3 Mode register. Unwanted 
interrupts must be masked off as described in 
Chapter 10. 



Table 9.1 Port 3 Line Functions 



Function 



Input 
Output 



Line 



Signal 



P3o-P33 Input 
P34-P37 Output 



Handshake 


P3i 


DAV2/RDY2 


Inputs 


"2 


OAVq/RDYq 




P'J 


DAV,/RDYi 


Handshake 


P34 


RDYi/DAV^ 


Outputs 


P'S 


RDYo/CaVq 




"6 


RDY2/DAV2 


Interrupt 


P'O 


IRQ3 


Requests 


P3l 


IRQ2 




P32 


IRQq 




P33 


IRQ1 


Serial Input 


P'O 


SI 


Output 


PJ7 


SO 


Counter/Timer 


P3l 


Tin 




P56 


Tout 



Status 



P3a 



DM 



R247 P3M 
Port 3 Mode Register 

(% F7; Write Only) 



P32 = INPU T P35 = OUTPUT 

1 P32 = DAVO/RDYO PSs - RDYO/DAVO 

P33 = INPUT P34 = OUTPUT 

-?J}P33 = INPUT P34 = mvi 

11 P33 = DAVT/RDYI P34 = RDY1/DAV1 



P3i = INPUT (Tin) P36 = OUTP UT (Tq ut) 
~1 P3i = DAV2/RDY2 P36 = RDY2/DAV2 



P3o = INPUT P37 = 

~ 1 P3o = SERIAL IN P37 : 



OUTPUT 
SERIAL OUT 



Figure 9-14. Port 3 I/O Operation 
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9.6 PORT HANDSHAKE 

When Ports 0, 1, or 2 are configured for hand- 
shake operation, a pair of lines from Port 3 is 
used for handshake controls for each port. The 
handshake controls are interlocked to properly 
time asynchronous data transfers between the Z8 
and its peripheral. One control line (DAV^j) func- 
tions as a strobe from the sender to indicate to 
the receiver that data is available. The second 
control line (RDY^) acknowledges receipt of the 
sender's data, and indicates when the receiver is 
ready to accept another data transfer. 

In the input mode, data is latched into the port's 
input register by the first DAV signal, and is 
protected from being overwritten if additional 
pulses occur on the DAV line. This overwrite pro- 
tection is maintained until the port data is 
read. In the output mode, data written to the 
port is not protected and can be overwritten by 
the Z8 during the handshake sequence. To avoid 
losing data, the software must not overwrite the 
port until the corresponding interrupt request 
indicates that the external device has latched the 
data. 

The software can always read Port 3 output and 
input handshake lines, but cannot write to the 
output handshake lines. 



Following is the recommended setup sequence when 
configuring a port for handshake operation for 
the first time after a reset: 

• Load P01M or P2M to configure the port for 
. input/output. 

• Load P3 to set the Output Handshake bit to a 
logic 1 . 

• Load P3M to select the Handshake mode for the 
port. 

Once a data transfer begins, the configuration of 
the handshake lines should not be changed until 
handshake is completed. 

Figures 9-15 and 9-16 show detailed operation 
for the handshake sequence. 

In applications requiring a strobed signal instead 
of the interlocked handshake, the Z8 can satisfy 
this requirement as follows: 

• In the Strobed Input mode, data can be latched 
in the port input register using the DAV 
input. The data transfer rate must allow 
enough time for the software to read the port 
before strobing in the next character. The RDY 
output is ignored. 



In the Strobed Output mode, the 
should be tied to the DAV output. 



RDY input 



DAV 
(INPUT TO Z8) 



RDY 
(OUTPUT FROM Z8) 



DATA ON PORT 
(INPUT TO Z8) 




State 1. Port 3 Ready output is High, indicating that the Z8 is read y to a ccept data. 

State 2. The I/O device puts data on the port and then activates the DAV input. This causes 
the data to be latched into the port input register and generates an interrupt re- 
quest. 

State 3. The Z8 forces the Ready (RDY) output Low, signaling to the I/O device that the 
data has been latched. 

State 4. The I/O device returns the DAV line High in response to RDY going Low. 

State 5. The Z8 software must respond to the interrupt request an«^ read the contents of 
the port in order for the handshake sequence to b e com pleted. The RDY line goes 
High if and only if the port has not been read and DAV is High. This returns the in- 
terface to its initial state. 



Figure 9-15. Z8 Input Handshake 
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I/O Ports 



RDY 
(INPUT TO Z8) 



DAV 
(OUTPUT FROM Z8) 



DATA ON PORT 
(OUTPUT FROM Z8) 



D( 



\ 



VALID DATA 




State 1. RDY input is High indicating that the I/O device is ready \o accept data. 

State 2. The Z8 writes to the p ort re gister to initiate a data transfer. Writing the port outputs 
new data and forces DAV Low if and only if RDY is High. 

State 3. The I/O device forces RDY Low after latching the data. RDY Low causes an inter- 
rupt request to be generated. The Z8 can write new data in response to RDY going 
Low; how ever, the data is not output until State 5. 

State 4. The DAV o utput from the Z8 is driven High in response to RDY going Low. 

State 5. After DAV goes High, the I/O device is free to raise RDY High thus returning the in- 
terface to its initial state. 



Figure 9-16. Z8 Output Handshake 



Figures 9-17 and 9-18 illustrate the strobed 
handshake connections. 



P20-P27 
Z8 

P3i 


A 


I/O 
DEVICE 


< 


N 

DAV 





9.7 I/O PORT RESET CONDITIONS 

After a hardware reset, mode registers P01M, P2M, 
and P3M are set as shown in Figures 9-19 - 9-22. 
Ports 0, 1 and 2 are configured for input opera- 
tion on all bits, except Port 1 in the Z8681 and 
Ports and 1 in the Z8682 as shown. 

The pull-ups of Port 2 are set for open-drain. If 
active pull-ups are desired for Port 3 outputs, 
remember to configure them using P3M (Figure 
9-22). 



Figure 9-17. Input Strobed Handshake 
using Port 2 



All special I/O functions of Port 3 are inactive, 
with P3q-P33 set as inputs and P34-P3y set as 
outputs (Figure 9-23). 



P20-P27 
Z8 

P36 
P3i 



^ 



RDY 



I/O 
DEVICE 



Figure 9-18. Output Strobed Handshake 
using Port 2 
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I/O Ports 



R248P01M 
Port 0-1 Mode Register 

(% F8; Write Only) 



PO4-PO7 MODE 
OUTPUT = 00 

INPUT = 01 " 
A12-A15 = 1X 

EXTERNAL MEMORY TIMING 
NORMAL = - 
* EXTENDED = 1 



PO0-PO3 MODE 

00 = OUTPUT 

01 = INPUT 
1X = A8-A11 

STACK SELECTION 
. = EXTERNAL 

I = INTERNAL 

PI0-PI7 MODE 

00 = BYTE OUTPUT 
- 01 = BYTE INPUT 
10 = AD0-AD7 

II = HjGmMPEDANCE AD0-AD7, 

AS, DS, R/W, A8-A11, A12-A15 



*ALWAYS EXTENDED TIMING AFTER RESET EXCEPT Z8682 



Figure 9-19. Z8601/11 Port and 1 Reset 



R248P01M 

Port 0-1 Mode Register 

(% F8; Write Only) 



PO4-PO7 MODE 
OUTPUT = 00 
INPUT = 01 
A12-A15 = 1X 

EXTERNAL MEMORY TIMING 
NORMAL = - 
•EXTENDED = 1 



PO0-PO3 MODE 

_ 00 = OUTPUT 

01 = INPUT 

IX = Ag-An 

STACK SELECTION 
- = EXTERNAL 
1 = INTERNAL 



*ALWAYS EXTENDED TIMING AFTER RESET EXCEPT Z8682 



Figure 9-20. Z8681 Ports and 1 Reset 



R248P01M 

Port 0-1 Mode Register 

(% F8; Write Only) 



PO4-PO7 MODE 
OUTPUT = 00 
INPUT = 01 
A12-A15 = 1X 

EXTERNAL MEMORY TIMING 
NORMAL = 
EXTENDED = 1 



F 








1 





■• 1 ■• 


^ 

















































PO0-PO3 MODE 

00 = OUTPUT 

01 = INPUT 
IX = As-A^i 

STACK SELECTION 

= EXTERNAL 

1 = INTERNAL 

PI0-PI7 MODE 
10 = AD0-AD7 



Figure 9-21. Z8682 Ports and 1 Reset 
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I/O Ports 



R246 P2M 
Port 2 Mode Register 

(% F6; Write Only) 



J 



P20-P27 MODE 
— OUTPUT 
1 INPUT 



Figure 9-22. Port 2 Reset 



R247P3M 

Port 3 Mode Register 

(% F7; Write Only) 



HI 









( 




( 




00 
01 




I 

I I 
( 



PORT 2 PULL-UPS OPEN DRAIN 
"1 PORT 2 PULL-UPS ACTIVE 



P32 = 

1 P32 = 



INPUT 
DAVO/ROYO 



P33 = INPUT 
} P33 = INPUT 
P33 = DiSvT/RDY1 



P35 = OUTPUT 

P35 = RDYO/DAVO 

P34 = OUTPUT 

P34 = DM 

P34 = RDY1/DAVi 



P3i = INPUT (Tin) P36 = OUTP UT (Tq ut) 

1 P3i = DAV2mDY2 P36 = ROY2/DAV2 



P3o = INPUT 

" 1 P3o = SERIAL IN 

_0 PARITY OFF 

1 PARITY ON 



P37 = OUTPUT 
P3o = SERIAL OUT 



Figure 9-23. Port 3 Reset 
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Chapter 10 
Interrupts 



10.1 INTRODUCTION 



10.2 INTERRUPT SOURCES 



The 'Z8 microcomputer allows six different inter- 
rupt levels from eight sources: the four Port 3 
lines P3q-P33 make up the external interrupt 
sources while serial in, serial out, and the two 
counter/timers make up the internal sources. 
These interrupts can be masked and their prior- 
ities set by using the Interrupt Mask and the 
Interrupt Priority registers. All six interrupts 
can be globally disabled by resetting the master 
Interrupt Enable bit Oy in the Interrupt Mask reg- 
ister with a Disable Interrupt (DI) instruction. 
Interrupts are globally enabled by setting D7 with 
an Enable Interrupt (EI) instruction. 

There are three interrupt control registers: the 
Interrupt Request register (IRQ), the Interrupt 
Mask register (IMR), and the Interrupt Priority 
register (IPR). Figure 10-1 shows addresses and 
identifiers for the interrupt control registers. 
Figure 10-2 is a block diagram showing the 
Interrupt Mask and Interrupt Priority logic. 

The Z8 family supports both vectored and polled 
interrupt handling i Details on vectored and 
polled interrupts can be found in Sections 10.6 
and 10.7. 



DEC 







251 


INTERRUPT MASK 


250 


INTERRUPT REQUEST 


249 


INTERRUPT PRIORITY 







HEX 


IDENTIFIERS 


FB 


IMR 


FA 


IRQ 


F9 


IPR 



Table 10-1 presents the interrupt types, sources, 
and vectors available in the Z8 family of 
processors. 



10.2.1 External Interrupt Sources 

External sources involve interrupts request lines 
IRQ0-IRQ3. IRQq, IRQ^, and IRQ2 are always gen- 
erated by a negative edge signal on the corre- 
sponding Port 3 pin (P32, P33, P3i correspond to 
IRQq, IRQi, and IRQ2, respectively). Figure 10-3 
is a block diagram for interrupt sources IRQq, 
IRQ1, and IRQ2. 

When the Port 3 pin (P3-|, P32, or P33) goes Low, 
the first flip-flop is set. The next two flip- 
flops synchronize the request to the internal 
clock and delay it by four external clock 
periods. The output of the last flip-flop (IRQqj 
IRQ1 , or IRQ3) goes to the corresponding Interrupt 
Request register. 

IRQ0-IRQ5 



Ji 



GLOBAL 

INTERRUPT 

ENABLE 



IT 

• • • 
1 I 



^ 



Figure 10-1. Interrupt Control Registers 



IIORITY L0( 

U 

VECTOR SELECT 



Figure 10-2. Interrupt Block Diagram 
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Tdble 10-1. 
Interrupt Types, Sources, and Vectors 



Name 


Source 


Vector 
Location 


Comnents 


IRQq. 


DAVq, IRQq 


0,1 


External (P32), ^ Edge Triggered 


IRQ-l 


DAV^, IRQ^ 


2,3 


External (P33), | Edge Triggered 


IRQ2 


DAV2, IRQ2, Tl|y 


J ^5 


External (P3i), y Edge Triggered 


IRQ3 


IRQ3 


6,7 


External (P3o), | Edge Triggered 


Serial In 


6,7 


Internal 


IRQ4 


To 

/ 


8,9 


Internal 


Serial Out 


8,9 


Internal 


IRQ5 


T1 


10,11 


Internal 



IRQ3 can be generated from an external source only a negative edge signal on P3q as shown in Figure 
if Serial In is not enabled; otherwise, its source 10-4. Again, the external request is synchronized 
is internal. The external request is generated by and delayed before reaching IRQ. 



















PI.. t 


1 = 2,3,1 


S Q 
R 




D Q 




D Q - 




_n 


=D- 


m = 0,1,2 
























CLO 
(INTERN 












AL) 











Figure 10-5. Interrupt Sources IRQ0-IRQ2 Block Diagram 



P3M6 




IRQ3 



Figure 10-4. Interrupt Source IRQ3 Block Diagra 
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10.2.2 Internal Interrupt Sources 

Internal sources involve interrupt requests 
IRQ3-IRQ5. If Serial In is enabled, IRQ3 gen- 
erates an interrupt request whenever the receiver 
assembles a complete byte. Interrupt level IRQ^ 
has two mutually exclusive sources, Counter/Timer 
(Tg) and the Serial Out transmitter. If Serial 
Out is enabled, an interrupt request is generated 
when the transmit buffer is empty. If Tq is 
enabled, an interrupt request is generated at Tg 
end-of-count. IRQ5 generates an interrupt request 
at Counter/Timer Vs {J^) end-of-count. 

For more details on the internal interrupt 
sources, refer to the chapters describing serial 
I/O and the counter/timers. 



Requests are sampled internally during the last 
clock cycle before an opcode fetch (Figure 10-6). 
External requests are sampled two internal clocks 
earlier, due to the synchronizing flip-flops shown 
in Figures 10-3 and 10-4. 

At sample time the request is transferred to the 
second flip-flop in Figure 10-5, which drives the 
interrupt mask and priority logic. When an 
interrupt cycle occurs, this flip-flop will be 
reset only for the highest priority level that is 
enabled. 

The user has direct access to the second flip-flop 
by reading and writing the IRQ register. IRQ is 
read by specifying it as the source register of an 
instruction and written by specifying it as the 
destination register. 



10.3 INTERRUPT REQUEST (IRQ) REGISTER LOGIC AID 
TIMING 



10.4 INTERRUPT INITIALIZATION 



Figure 10-5 shows the logic diagram for the 
Interrupt Request register. The leading edge of 
the request will set the first flip-flop, which 
will remain set until interrupt requests are 
sampled. 



After reset, all interrupts are disablpd and must 
be initialized before vectored or polled interrupt 
processing can begin. The Interrupt Priority reg- 
ister (IPR), Interrupt Mask register (IMR) and 
Interrupt Request register (IRQ) must be initial- 
ized, in that order, to start the interrupt 
process. However, IPR need not be initialized for 
polled processing. 



IRQo^lRQs 




FROM PRIORITY 
LOGIC 



TO MASK 
AND 

PRIORITY 
LOGIC 



Figure 10-3. IRQ, Register Logic 



Mn 



Mi 



I ^2 I 



FT T2 T3 



Ti T2 T3 Ti 



T2 "tT] 



INTERRUPT REQUESTS 
SAMPLED INTERNALLY 



EXTERNAL INTERRUPT 
REQUESTS SAMPLED 



Figure 10-6. Interrupt Request Tilling 
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Interrupts 



10.4.1 



Interrupt Priority Register (IPR) 
Initialization 



IPR (Figure 10-7) is a write-only register that 
sets priorities for the six levels of vectored 
interrupts in order to resolve simultaneous 
interrupt requests. (There are 48 sequence 
possibilities for interrupts.) The six interrupt 
levels IRQQ-IRQ5 are divided into three groups of 
two interrupt requests each. One group contains 



IRQ3 (SI/P3o) and IRQ5 (T^), another group 
contains IRQg {P^2^ ^"^ IRQ2 (P3i), and the third 
group contains IRQ^ (P33) and IRQ4 (SO/Tg). 

Priorities can be set both within and between 
groups as shown in Table 10-2. Bits D^ , D2, and 
D5 define the priority of the individual members 
within the three groups. Bits Dq, D3, and D^ are 
encoded to define six priority orders between the 
three groups. Bits Dg and Dj are not used. 



R249 IPR 
Interrupt Priority Register 

(% F9; Write Only) 



IRQ3, iRQ5 PRIORITY (GROUP A) 

= IRQ5 > IRQ3 

1 = IRQ3 > IR05 

IRQO, IRQ2 PRIORITY (GROUP B) 

= IRQ2 > IRQO 

1 = IRQO > IRQ2 

IRQ1, IRQ4 PRIORITY (GROUP C) 

= IRQ1 > IRQ4 

1 = tRQ4 > IRQ1 



D5 D4 D3 D2 Di Dp] 

J I _— .._iu u. 



INTERRUPT GROUP PRIORITY 
RESERVED - 000 
> A > B = 001 
A > B > = 010 
A > > B = Oil 
B > C > A = 100 
C > B > A = 101 
B > A > C = 110 
RESERVED =111 



Figure 10-7. Interrupt Priority Register 



Table 10-2. Interrupt Priority 



Group Bit Priority 

Highest Lowest 



Di=0 



Do=0 



Dc=0 



IRQ1 
IRQ4 

IRQ2 

IRQg 

IRQ5 
IRQ3 



IRQ4 
IRQ1 

IRQq 
IRQ2 

IRQ3 
IRQ5 



Bit Pattern 



Do 


















1 





1 








1 


1 


1 








1 





1 


1 


1 





1 


1 


1 



Group Priority 
Highest — > Lowest 



NOT USED 


CAB 


ABC 


A C B 


B C A 


C B A 


B A C 


NOT USED 
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Interrupts 



SP AND STACK 
BEFORE INTERRUPT 



SP AND STACK 
AFTER INTERRUPT 



SP 



TOP OF STACK 



PCl 



PCu 



FLAGS 



Figure 10-10. Effect of Interrupt on Stack 



INTERRUPT 
-SERVICE 
ROUTINE 



VECTOR SELECTED BY 
PRIORITY LOGIC 



INTERRUPT 

VECTOR 

TABLE 



Z8 PROGRAM MEMORY 



Figure 10-11. Interrupt Vectoring 



10.6 VECTORED PROCESSING 

Each Z8 interrupt level has its own vector. When 
an interrupt occurs, control passes to the service 
routine pointed to by the interrupt 's location in 
program memory. The sequence of events for vec- 
tored interrupts is as follows: 

• PUSH PC Jower byte on stack 

• PUSH PC upper byte on stack 

• PUSH FLAGS on stack 

• Fetch upper byte of vector 

• Fetch lower byte of vector 

• Branch to service routine specified by vector 

Figures 10-10 and 10-11 show the vectored 
interrupt operation. 



10.6.1 Vectored Interrupt Cycle lining 

Interrupt cycle timing for all Z8 devices except 

the Z8681 is diagrammed in Figure 10-12. Timing 

for the Z8681 ROMless device is different and is 
shown in Figure 10-13. 



10.6.2 Nesting of Vectored Interrupts 

Nesting ^f vectored interrupts allows higher 
priority requests to interrupt a lower priority 
request. To initiate vectored interrupt nesting, 
do the following during the interrupt service 
routine: 

• Push the old IMR on the stack. 

• Load IMR. with a new mask to disable lower 
priority interrupts, 

• Execute EI instruction. 

• Proceed with interrupt processing. 

• After processing is complete, execute DI 
instruction. 

• Restore the IMR to its original value by 
returning the previous mask from the stack. 

• Execute IRET. 

Depending on the application, some simplification 
of the above procedure may be possible. 



10.7 POLLED PROCESSING 

Polled interrupt processing is supported by 
masking off the IRQ levels to be polled. This is 
accomplished by clearing the corresponding bit in 
the IMR to 0. 
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To initiate polled processing, check the bits of 
interest in the IRQ using the Test Under Mask (TM) 
instruction. If the bit is set, call or branch to 
the service routine. The service routine services 
the request, resets its Request bit in the IRQ, 
and branches or returns back to the main program. 
An example of a polling routine is as follows: 



10.8 RESET CONDITIONS 

During a reset, all bits in IPR are undefined. 

In IMR, bit D-j is and bits Dq-D^ are undefined. 
Bit Dg is not implemented, though reading this bit 
returns 0, 



TM IRQ,#MASK 
JR Z NEXT 
CALL SERVICE 



NEXT: 



! Test for request ! 

!If no request go to NEXT ! 

!If request is there ! 

! then service it ! 



IRQ bits DQ-D5 are held at until an EI instruc- 
tion is executed. Bits Dg and Dy are not imple- 
iTiented, but reading these bits returns 0. 



SERVICE: 



'.Process Request 



AND IRQ,#MASK_ ! Clear Request bit ! 
RET ! Return to next ! 

In this example, if IRQ2 is being polled, MASK 
will be ?i200000100 (in binary) and MASK_ will be 
5^211111011. 
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j,, — Mi ^j.. M2 »| < M3 ^j.. STACK PUSH__^|„ STACK PUSH ^j,, STACK PUSH ^^j,, Mr »^\^ Mi .►j,. M2 



«"ij u u u u — u u u u^ 

~ — 1_^ i—^J=5 nil — I K^ 1 <H I — 1=^ 

^FOR EXTERNAL EXECUTION ONLY ^^ FOR STACK EXTERNAL ONLY-*'^- ^~- FOR EXTERNAL EXECUTION ONLY 

AD0-AD7 OUT I PC I / I PC + l| I PC I I SP-1 I PCl I SP-2 I PCu | SP-3 | FLAGS |flAGs| | VECT | | | 

AD0-AD7IN V | 1 ^ OPCODE (DISCARDED) FIRST INSTRUCTION^OMNTERRWT_^ |-"^ 

R/W I | -*--F< 



-FOR STACK EXTERNAL ONLY 



Figure 10-12. ROM Z8 Interrupt Tining (shrink parts) 
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Figure 10-13. Z8681 RONless Z8 Interrupt Tiung 
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Chapter 11 
Counter/Timers 



11.1 INTRODUCTION 



The Z8 provides two 8-bit counter/timers, Tg and 
r>], each driven by its own 6-bit prescaler, PREq 
and PRE>j . Both counter/timers are independent of 
the processor instruction sequence, which relieves 
software from time-critical operations such as 
interval timing or event counting. 



Each counter/timer operates in either Single-Pass 
or Continuous mode. At the end-of-count, counting 
either stops or the initial value is reloaded and 
counting continues. Under software control, new 
values are loaded immediately or when the end-of- 
count is reached. Software also controls counting 
mode, how a counter/timer is started or stopped, 
and its use of I/O lines. Both the counter and 
prescaler registers can be altered while the 
coUnter/timer is running. 
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Counter/Timers 



Counter/timers and 1 are driven by a timer clock 
generated by dividing the internal clock by four. 
The divide-by-four stage, the 6-bit prescaler, and 
the 8-bit counter /timer form a synchronous 16-bit 
divide chain. Counter/timer 1 can also be driven 
by an external input (Tjfy|) via Port 3 line P3^ . 
Port 3 line P3g can serve as a timer output 
(Tgyj) through which Tq, Ti, or the internal 
clock can be output. The timer output will toggle 
at the end-of-count. Figure 11-1 is a block 
diagram of the counter/timers. 

The counter/timer, prescaler, and associated mode 
registers are mapped into the register file as 
shown in Figure 11-2. This allows the software to 
treat the counter /timers as general-purpose 
registers, and eliminates the need for special 
instructions. 



11.2 PRESCALERS AND COUNTER/I IHERS 



register which holds the initial count value, and 
a read-only register which holds the current coynt 
value (Figure 11-1). The initial value can range 
from 1 to 256 decimal (S501 ,%02,.. ,SSOO). Figure 
11-5 illustrates the counter/timer registers. 
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The prescalers, PREq (%F5) and PRE-, (5«F3), each 
consist of an 8-bit register and a 6-bit 
down-counter as shown in Figure 11-1. The 
prescaler registers are write-only registers. 
Reading the prescalers returns the value 5oFF. 
Figures 11-3 and 11-4 show the prescaler 
registers. 

The six most significant bits (02-0-7) of PREg or 
PRE^ hold the prescalers count modulo, a value 
from 1 to 64 decimal. The prescaler registers 
also contain control bits that specify Tq and T^, 
counting modes. These bits also indicate whether 
the clock source for T-j is internal or external. 
These control bits will be discussed in detail 
throughout this chapter. 

The counter/timers, Tq ' (S»F4) and T1 (S0F2), each 
consist of an 8-bit down-counter, a write-only 



DEC 







247 


PORT 3 MODE 






245 


TO PRESCALER 


244 


TIMER/COUNTER 


243 


T1 PRESCALER 


242 


TIMER/COUNTER 1 


241 


TIMER MODE 







HEX IDENTIFIERS 



F7 P3M 



F5 


PREO 


F4 


TO 


F3 


PRE1 


F2 


T1 


F1 


TMR 



Figure 11-3. Prescaler Register 



R243PRE1 
Prescaler 1 Register 

(% F3; Write Only) 



|d7|d, 



D4 D; 



Di D, 



L 



COUNT MODE 
1 = Ti MODULO-N 
= Ti SINGLE-PASS 

CLOCK SOURCE 
-1 = Ti INTERNAL 
= Ti EXTERNAL (Tin) 

PRESCALER MODULO 
-(RANGE: 1-64 DECIMAL 
01-00 HEX) 



Figure 11-4. Prescaler 1 Register 



R242 T1 
Counter/Timer 1 Register 

(% F2; Read/Write) 

R244 TO 

Counter/Timer Register 

(% F4; Read/Write) 



|d7 Dfi Dg D4 Dg D2 Di DqI 



INITIAL VALUE WHEN WRITTEN 
- (RANGE 1-256 DECIMAL, 01-00 HEX) 
CURRENT VALUE WHEN READ 



407 



11.3 CQMNTERAIHER OPERAriON 

Under software control, counter /timers are started 
and stopped via the Timer Mode register (SdFT) bits 
Dq-Dj (Figure 11-6). Each counter/timer is asso- 
ciated with a Load bit and an Enable Count bit. 



both reach their epd-of-count, an interrupt 
request is generated — IRQ4 for Fq and IRQ5 for 
Ti . Depending on the counting mode selected, the 
counter/timer will either come to rest with its 
value at ?oOO (Single-Pass mode) or the initial 
value will be automatically reloaded and counting 
will continue (Continuous mode). 



11.3.1 Load and Enable Count Bits 

Setting the Load bit (Dq to 1 for Tq and D2 to 1 
for T>j) transfers the initial value in the pre- 
scaler and the counter/timer registers into their 
respective down-counters. The next internal clock 
resets bits Dg and D2 to 0, readying the Load bit 
for the next load operation. The initial values 
may be loaded into the down-counters at any time. 
If the counter/timer is running, it continues to 
do so and starts the count over with the initial 
value. Therefore, the Load bit actually functions 
as a software re-trigger. 

The counter/timers remain at rest as long as the 
Enable Count bits D>| and D3 are both 0. To enable 
counting, the Enable Count bit (D-j for Tq and D3 
for T^) must be set to 1. Counting actually 
starts when the Enable Count bit is written by an 
instruction. The first decrement occurs four 
internal clock periods after the Enable Count bit 
has been set. 

The Load and Enable Count bits can be set at the 
same time. For example, using the instruction OR 
TMR #%03 sets both Dg and D^ of TMR to 1. This 
loads the initial values of PREg and Tg into their 
respective counters and starts the count after the 
M2r2 machine state after the operand is fetched 
(Figure 11-7). 
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11.3.2 Prescaler Operations 

During counting, the programmed clock source 
drives the prescaler 6-bit counter. The counter 
is counted down from the value specified by bits 
D2-D-7 of the corresponding prescaler register, 
PREg or PRE^ (Figure 11-8). When the prescaler 
counter reaches its end-of-count, the initial 
value is reloaded and counting continues. The 
prescaler never actually reaches 0. For example, 
if the prescaler is set to divide by 3, the count 
sequence is: 

3-2-1-3-2-1-3-2.... 

Each time the prescaler reaches its end-of-count a 
carry is generated, which allows the counter/timer 
to decrement by one on the next timer clock 
input. When the counter/timer and the prescaler 



Figure 11-7. Starting The Count 
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Figure 11-8. Counting Modes 



408 



Counter/Timers 



The counting modes are controlled by bit Dg of register P3M (?oF7) (Figure 11-9) to configure P3^ 

for Tgyi operation. In order for Iq^j to 
function, P3^ must be defined as an output line by 
setting P3M bit D5 to 0. Output is controlled by 
one of the counter/timers 
internal clock. 
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The counter/timers can be stopped at any time by 
setting the Enable Count bit to 0, and restarted 
by setting it back to 1. The counter/timer will 
continue its count value at the time it was 
stopped. The current value in the counter/timer 
(Tg or T>|) can be read at any time without 
affecting the counting operation. 

New initial values can be written to the prescaler 
or the counter/timer registers at any time. These 
values will be transferred to their respective 
down-counters on the next load operation. If the 
counter/timer mode is Continuous, the next load 
occurs on the timer clock following an 
end-of-count. New initial values should be 
written before the desired load operation, since 
the prescalers always effectively operate in 
Continuous count mode. 

The time interval (i) until end-of-count, is given 
by the equation 

i = t X p X V 

in which t is 8 divided by XTAL frequency, p is 
the prescaler value (1 - 64), and v is the 
counter/timer value (1 - 256). It should be 
apparent that the prescaler and counter/timer are 
true divide-by-n counters. 



(Tg or T-j) or the 



The counter/timer to be output is selected by TMR 
bits D7 and D/-. 



'OUT 



fg is selected to drive the 
line by setting D-j to and D^ to 1. 
Likewise, T1 is selected by setting Dy and D^ to 1 
and respectively. The counter/timer Tgyj mode 
is turned off by setting TMR bits Dy and D^ both 
to 0, freeing P3g to be a data output line. 

Tggy is initialized to a logic 1 whenever the 
TMR Load bit (Dg for Tg or P2 for f^) is set to 1. 
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The Timer Mode register TMR (5SF1) (Figure 11-10) 
is used in conjunction with the Port 3 Mode 
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At end-of-count, the interrupt request line (IRQ^ 
or IRQ5), clocks a toggle flip-flop. The output 
of this flip-flop drives the Tgyj line, P3g. In 
all cases, when the selected counter/timer reaches 
its end-of-count, Tgyj toggles to its opposite 
state (Figure 11-11). If, for example, the 
counter/timer is in Continuous counting mode, 
Tgyj will have a 50Sb duty cycle output. This 
duty cycle can easily be controlled by varying the 
initial values after each end-of-count. 

The internal, clock can be selected as output 
instead of Tg or T>| by setting TMR bits Dy and Dg 
both to 1. The internal clock (XTAL frequency/2) 
is then directly output on P3g (Figure 11-12). 
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While programmed as Tgyj, P3g cannot be modified 
by a write to port register P3. However, the Z8 
software can examine P3g's current output by 
reading the port register. 
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Figure 11-13. Tiaer Node Register Tj|^ Operation 
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The Timer Mode register TMR (%F1) (Figure 11-13) 
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Counter/Timers 



The counter/timer clock source must be configured 
for external by setting PRE>| bit D2 to 0. The 
Timer Mode register bits D5 and D^ can then be 
used to select the desired Tj[y| operation. 

For fi to start counting as a result of a Jj^^ 
input, the Enable Count bit D3 in TMR must be set 
to 1. When using J^^ as an external clock or a 
gate input, the initial values must be loaded into 
the down-counters by setting the Load bit D2 in 
TMR to a 1 before counting begins. In the 
descriptions of Tj|yj that follow, it is assumed 
that the programmer has performed these opera- 
tions. Initial, values are automatically loaded 
in Trigger and Retrigger modes so software loading 
is unnecessary. 

It is suggested that P3^ be configured as an input 
line by setting P3M bit D5 to although Tj|y| is 
still functional if P3>| is configured as a hand- 
shake input. 



Each High-to-Low transition 



'IN 



generates 



interrupt request IRQ2» regardless of the selected 
Tj|y| mode or the enabled/disabled state of T>|. 
IRQ2 must therefore be masked or enabled according 
to the needs of the application. 



11.3.1 External Clock Input Mode 

The Tj|y| External Clock Input mode (TMR bits D5 
and D^ both set to 0) supports counting of 
external events, where an event is considered to 
be a High-to-Low transition on Tj|y| (Figure 
11-15). occurrence (Single-Pass mode) or on every 
nth occurrence (Continuous mode) of that event. 



11.5.2 Gated Internal Clock Mode 



The Tj|yj Gated Internal Clock mode (TMR bits D^ 
and D^ set to and 1 respectively) measures the 
duration of an external eVent. In this mode, the 
T-i prescaler is driven by the internal timer 
clock, gated by a High level on 1^^ (Figure 
11-16), Ti counts while Tj|y| is High and stops 
counting while Tj|y| is Low. Interrupt request 
IRQ2 is generated on the High-to-Low transition of 
Tj|yj, signaling the end of the gate input. 
Interrupt request IRQ5 is generated if T^ reaches 
its end-of-count. 
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Figure 11-18. Cascaded CounterAiners 



Counter/Timers 



11.3.3 Triggered Input Mode 

The Tji^ Triggered Input mode (TMR bits D5 and 
D^ set to 1 and respectively) causes 1^ to start 
counting as the result of an external event 
(Figure 11-17). T^j is then loaded and clocked by 
the internal timer clock following the first High- 
to-Low transition on the Tj|yj input. Subsequent 



'IN 



transitions do not affect Ti 



In the Sin- 



gle-Pass mode, the Enable bit is reset whenever T^ 



reaches its end-of-count. Further T 



IN 



transi- 



tions will have no effect on J^ until software 
sets the Enable Count bit again. In Continuous 
mode, once T^ is triggered counting continues 
until software resets the Enable Count bit. 
Interrupt request IRQ5 is generated when T^ 
reaches its end-of-count. 



IRQ4 (Tq end-of-count) are also generated but are 
most likely of no importance in this configuration 
and should be disabled. 



11.7 RESET CONDITIONS 

After a hardware reset, the counter/timers are 
disabled and the contents of both the counter/ 
timer registers and the prescaler modulos are 
undefined. However, the counting modes are 
configured for Single-Pass and T^'s clock source 



is set for external. 



'IN 



is set for External 



Clock mode, and the Tgyj mode is off. Figures 
11-19 through 11-22 show the binary reset values 
of the Prescaler, Counter/Timer, and Timer Mode 
registers. 



11.3.4 Retriggerable Input Node 

The Tji^ Retriggerable Input mode (FMR bits D5 
and D^ both set to 1) causes Tv| to load and start 
counting on every occurrence of a High-to-Low 
transition on J-^^ (Figure 11-17). Interrupt 
request IRQ5 will be generated if the programmed 
time interval (determined by J^ prescaler and 
counter/timer register initial values) has elapsed 
since the last High-to-Low transition on Tj|y|. 
In Single-Pass mode, the end-of-count resets the 
Enable Count bit. Subsequent Tj|g transitions 
will not cause T>| to load and start counting until 
software sets the Enable Count bit again. In Con- 
tinuous mode, counting continues once T^ is trig- 
gered until software resets the Enable Count bit. 
When enabled, each High-to-Low Tj^g transition 
causes T>| to reload and restart counting. Inter- 
rupt request IRQ5 is generated on every end-of- 
count • 
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Figure 11-19. Counter A imr Reset 
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11.6 CASCADING COUNTER/TIKERS 

For some applications, it may be necessary to mea- 
sure a time interval greater than a single coun- 
ter/timer can measure. In this case, Tj|yj and 
Tgyj can be used to cascade Tg and T^ as a sin- 
gle unit (Figure 11-18). Tg should be configured 
to operate in Continuous mode and to drive 
Tgyj. Tjfg should be configured as an external 
clock input to T^ and wired back to Tgyj. On 
every other Tg end-of-count, Tgyj undergoes a 
High-to-Low transition which causes T>| to count. 
T^ can operate in either Single-Pass or Continuous 
mode. Each time T^'s end-of-count is reached, 
interrupt request IRQ5 is generated. Interrupt 
requests IRQ2 (Tj|y| High-to-Low transitions) and 
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Chapter 12 
Serial I/O 



12.1 INTRODUCTION 

The Z8 microcomputer contains an on-board 
full-duplex receiver/transmitter for asynchronous 
data communications. The receiver/transmitter 
consists of a Serial I/O register SIO {%F^) and 
its associated control logic (Figure 12-1). The 
SIO is actually two registers — the receiver buffer 
and the transmitter buffer — which are used in 
conjunction with counter/timer Tg and Port 3 I/O 
lines P3q (input) and P37 (output). Counter/timer 
Fq provides the clock input for control of the 
data rates. 

Configuration of the serial I/O is controlled by 
the Port 3 Mode register, P3M. The Z8 always 
transmits 8 bits between the start and stop bits; 
that is, 8 data bits or 7 data bits and 1 parity 
bit. Odd parity generation and detection is 
supported. 

The Serial I/O register and its associated Mode 
Control registers are mapped into the register 
file as shown in Figure 12-2. This organization 



allows the software to access the serial I/O as 
general-purpose registers, eliminating the need 
for special instructions. 



12.2 BIT RATE GENERATION 

When Port 3 Mode register bit Og is, set to 1, the 
serial I/O is enabled and Tq automatically becomes 
the bit rate generator (Figure 12-3). Tq's end- 
of-count signal no longer generates interrupt 
request IRQ^; instead, the signal is used as the 
input to the divide-by-16 counters (one each for 
the receiver and the transmitter) which clock the 
data stream. 

The divide chain that generates the bit rate is 
shown' in Figure 12-4. The bit rate is given by 
the following equation: 

bit rate = XTAL frequency/ (2 x4xpxtx16) 

where p and t are the initial values in the 
Prescaler and Counter/Timer registers, 
respectively. 
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Serial I/O 



The final divide-by-16 is required since Tg runs 
at 16 times the bit rate in order to synchronize 
on the incoming data. 

To configure the Z8 for a specific bit rate, 
appropriate values as determined by the above 
equation must be loaded into registers PREq (%!i^5) 
and Tq (%F4). PREq also controls the counting 
mode for Tq and should therefore be set to the 
Continuous mode (D^ set to 1). 

For example, given an input clock frequency 
(fXTAL) of 11.9808 MHz and a selected tit rate of 
1200 bits per second, the equation is satisfied by 
p=39 and t=2. Counter /timer Tq should be set to 
5o02. With Tq in Continuous mode, the value of 
PREq becomes ?b9D (Figure 12-5). 
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Figure 12-2. Serial I/O Register Nap 



Table 12-1 lists several commonly used bit rates 
and the values of fXTAL, p, and t required to 
derive them. This list is presented for conven- 
ience and is not intended to be exhaustive. 

The bit rate generator is started by setting the 
Timer Mode register TMR (%F1) bits D^ and Dq both 
to 1 (Figure 12-6). This transfers the contents 
of the Prescaler and Counter /Timer registers to 
their corresponding down-counters. In addition, 
counting is enabled so that serial I/O operations 
begin. 
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P3o = INPUT P37 = OUTPUT 

"1 P3o = SERIAL IN P37 = SERIAL OUT 



Figure 12-3. Port 3 Node Register 
and Bit Rate Generation 



'"'HZHZHZHZHZh 

PREO TO 



BIT 

RATE 

CLOCK 



Figure 12-4. Bit Rate Divide Chain 



Table 12-1. Bit Rate 



Bit 
Rate 


7,3728 


7,9872 


9,8304 


11,0592 


11,6736 


11,9808 


12,2880 


P t 


P t 


P t 


P t 


P t 


P t 


P t 


19200 

9600 

4800 

2400 

1200 

600 

300 

150 

110 


3 1 
3 2 
3 4 
3 8 
3 16 
3 32 
3 64 
3 128 
3 175 


13 1 
13 2 
13 4 
13 8 
13 16 
13 32 
3 189 


4 1 
4 2 
4 4 
4 8, 
4 16 
4 32 
4 64 
4 128 
4 175 








5 1 
5 2 
5 4 
5 8 
5 16 
5 32 
5 64 
5 128 ' 
8 109 


9 1 
9 2 
? 4 
9 8 
9 16 
9 32 
9 64 
5 157 






19 1 
19 2 
19 4 
19 8 
19 16 
19 32 
4 207 


39 1 
39 2 
39 4 
39 8 
39 16 
17 50 



416 



Serial I/O 



R245 PREO 
Prescaler Register 

(% F5; Write Only) 



L 



COUNT MODE 

= To SINGLE-PASS 

1 = To MODULO-N 



- PRESCALER MODULO 
= 64 



Figure 12-3. Prescaler Register 
and Bit Rate Generation 



12.3 RECEIVER OPERATION 

The receiver consists of a , receiver buffer (SIO 
[SbFO]), a serial-in, parallel-out Shift register, 
parity checking, and data synchronizing logic. 
The receiver block diagram is shown as part of 
Figure 12^1. 



12.3.1 Receiver Shift Register 

After a hardware reset or after a character has 
been received, the Receiver Shift register is 
initialized to all 1s and the shift clock is 
stopped. Serial data, input through Port 3 pin 
P3q, is synchronized to the internal clock by two 
D-type flip flops before being input to the Shift 
register and the start bit detection circuitry. 



R241 TMR 
Timer Mode Register 

(% F1; Read/Write) 



3i|Do| 



L 



= NO FUNCTION 

1 = LOAD To 

= DISABLE To COUNT 
" 1 = ENABLE To COUNT 



Figure 12-6. Timer Mode Register 
and Bit Rate Generation 



The start bit detection circuitry monitors the 
incoming data stream, looking for a start bit (a 
High-to-Low input transition). When a start bit 
is detected, the shift clock logic is enabled. 
The Tq input is divided by 16 and, when the count 
equals 8, the divider outputs a shift clock. This 
clock shifts the start bit into the Receiver Shift 
register at the center of the bit time. Before 
the shift actually occurs, the input is rechecked 
to ensure that the start bit is valid. If the 
detected start bit is false, the receiver is reset 
and the process of looking for a start bit is 
repeated. If the start bit is valid, the data is 
shifted into the Shift register every sixteen 
counts until a full character is assembled (Figure 
12-7). 



(R) 
RCVR 
DATA 



K 



START BIT 

TRANSITION 

DETECTED 



~T_r~i 



STOP BIT 
1 OR MORE 



ZL 



i__rm 



SHIFT 
CLOCK ' 



runj-LrLTLrLrLnj-L 

U— 8 TO COUNTS LATER SHIFTING STARTS 



RCVR 
IRQ3 



JT^ 



SHIFT REGISTER CONTENTS 

TRANSFERRED TO RECEIVER 

BUFFER AND IRQ3 IS 

GENERATED 



Figure 12-7. Receiver Timing 
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After a full character has been assembled in the 
Shift register, the data is transferred to the 
receiver's buffer, SIO (5oF0), and interrupt 
request IRQ3 is generated. The shift clock is 
stopped and the Shift register reset to all 1s. 
The start bit detection circuitry begins monitor- 
ing the data input for the next start bit. This 
cycle allows the receiver to synchronize on the 
center of the bit time for each incoming charac- 
ter. 



12.3.2 Overwrites 

Although the receiver is buffered, it is not pro- 
tected from being overwritten, so the software 
must read the SIO register within one character 
time after the interrupt request. The Z8 does not 
have a flag to indicate this overrun condition. 
If polling is used, the IRQ3 bit in the Interrupt 
Request register must be reset by software. 



12.3.3 Franing Errors 

Framing error detection is not supported by the 
receiver hardware, but by responding to the inter- 
rupt request within one character bit time, the 
software can test for a stop bit at P3o. Port 3 
bits are always readable, which facilitates break 
detection. For example, if a null character is 
received, testing P3q results in a being read. 



12.3.4 Parity 

The data format supported by the receiver must 
have a start bit, eight data bits, and at least 
one stop bit. If parity is on, bit D-j of the data 
received will be replaced by a Parity Error flag. 
A parity error sets Dy to 1 ; otherwise, Dy is set 
to 0. F\igure 12-8 shows these data formats. 

The ZB hardware supports odd parity only, which is 
enabled by setting Port 3 Mode register bit Dy to 
1 (Figure 12-9). If even parity is required, the 
Parity mode should be disabled (i.e. P3M Dy set to 
0), and software must calculate the received 
data's parity. 



12.4 TRANSNIirER OPERATION 

The transmitter consists of a transmitter buffer 
(SIO (?oF0)), a parity generator, and associated 
control logic. The transmitter block diagram is 
shown as part of Figure 12-1. 

After a hardware reset or after a character has 
been transmitted, the transmitter is forced to a 
marking state (output always High) until a charac- 
ter is loaded into the transmitter buffer, SIO 
(5oF0). The transmitter is loaded by specifying 
the SIO as the destination register of any 
instruction. 



Received Data 
(No Parity) 



sp|d7|d6|d5|d4 


D3 D2 Di Do ST 












— 









START BIT 
EIGHT DATA BITS 
ONE STOP BIT 



Received Data 
(With Parity) 



|sp| p |d6|d5|d4|d3|d2|di|do|st| 



L 



START BIT 
SEVEN DATA BITS 
PARITY ERROR FLAG 
ONE STOP BIT 



Figure 12-8. Receiver Data Formats 
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R247 P3M 
Port 3 Mode Register 

(% F7; Write Only) 



D, Do 



Di|Do| 



_0 PARITY OFF 
1 PARITY ON 



Figure 12-9. Parity and Port 3 Node Register 



Tq's output drives a divide-by-16 counter which in 
turn generates a shift clock every 16 counts. 
This counter is reset when the transmitter buffer 
is written by an instruction. This reset 
synchronizes the shift clock to the software. The 
transmitter then outputs one bit per shift clock, 
through Port 3 pin P^j, until a start bit, the 
character written to the buffer, and two stop bits 
have been transmitted. After the second stop bit 
has been transmitted, the' output is again forced 
to a marking state. Interrupt request IRQ^ is 



12.4.1 Overwrites 

The user is not protected from overwriting the 
transmitter, so it is up to the software to 
respond to IRQ^ appropriately. If polling is 
used, the IRQ^ bit in the Interrupt Request regis- 
ter must be reset. 



12.4.2 Parity 

The data format supported by the transmitter has a 
start bit, eight data bits, and at least two stop 
bits. If parity is on, bit Dy of the data trans- 
mitted will be replaced by an odd parity bit. 
Figure 12-10 shows the transmitter data formats. 

Parity is enabled by setting Port 3 Mode register 
bit Dy to 1. If even parity is required, the 
parity mode should be disabled (i.e. P3M Dy set to 
d), and software must modify the data to include 
even parity. 

Since the transmitter can be overwritten, the user 
is able to generate a break signal. This is done 
by writing null characters to the transmitter buf- 
fer (SIO, %FQ) at a rate which does not allow the 
stop bits to be output. Each time the SIO is 
loaded, the divide-by-16 counter is re-synchro- 
nized and a new start bit is output followed by 
data. 



Transmitted Data 
(No Parity) 



[iT 


SP D, D, Ds D, 


D, DjJD, Do ST 












L 









START BIT 
EIGHT DATA BITS 
TWO STOP BITS 



Transmitted Data 
(With Parity) 



D2|Di|Do|ST 

L 



START BIT 
SEVEN DATA BITS 
ODD PARITY 
TWO STOP BITS 



Figure 12-10. Transinitter Data Formats 
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12.5 RESET CONDITIONS 

After a hardware reset, the Serial I/O register 
contents are undefined, and Serial mode and parity 
are disabled. Figures 12-11 and 12-12 show the 
binary reset values of the Serial I/O register and 
its associated mode register P3M. 



R240SIO 
Serial I/O Register 

(% FO; Read/Write) 



- SERIAL DATA (Dq = LSB) 



Figure 12-11. Serial I/O Register Reset 



R247 P3IVI 

Port 3 Mode Register 

(% F78; Write Only) 



HI 



- 








( 
( 




00 
01 




I 

I I 











PORT 2 PULL-UPS OPEN DRAIN 
""1 PORT 2 PULL-UPS ACTIVE 



P32 = INPUT P35 

1 P32 = DAVO/RDYO P35 



OUTPUT 

RDYO/DAVO 



INPUT 



P34 = OUTPUT 



1 o}P33 = INPUT 



P34 
P33 = DAV1/RDY1 P34 

P31 = INPUT (T,n) P36 

1 P31 = DAV2/RDY2 P36 



0P30 : 
1 P30 : 



INPUT P37 : 

SERIAL IN P37 : 



DM 
RDY1/DAV1 

OUTP UT (To ut) 
RDY2/DAV2 

OUTPUT 
SERIAL OUT 



PARITY OFF 

1 PARITY ON 



Figure 12-12, Port 3 Register Reset 
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Appendix A 
Pin Descriptions 
and Functions 



This appendix contains pin information and physi- 
cal descriptions for the Z8 development device 
(Z8612) and Protopack emulator (Z8603/13). Pin 
descriptions for the Z8601/11 and Z8681/82 micro- 
computers can be found in Chapters 6 and 7, 
respectively. 



A.I DEVELOPMENT DEVICE (Z8612) 

The pin mnemonics and descriptions presented for 
the Z8 microcomputers (Chapter 6) also apply to 
the development device. Additional pin descrip- 
tions are as follows: 

Aq-A^|. Prograa Nenory Address (outputs). These 
lines are used to access the first 4K bytes of the 
external program memory. 

Dg-Dy. Piogram Data (inputs). Data from the 
external program memory is input through these 
pins. 

lACK. Interrupt AcknoMledge (output, active 
High). lACK is driven High in response to an 
interrupt during the interrupt machine cycle. 

HDS. Progran Memory Data Strobe (output, active 
Low). MD5 is Low during an instruction fetch 



cycle when the first 4K bytes of program memory 
are being accessed. 

SCLK. System Clock (output). SCLK is the inter- 
nal clock output through a buffer. The clock rate 
is equal to one-half the crystal frequency. 

SYNC. Instruction Sync (output, active Lom). 

This strobe output is forced Low during the inter- 
nal clock period preceding an opcode fetch. 



A.2 PROTOPACK EMULATOR (Z8603/13) 

Both the Z8603 and Z8613 devices use a 40-pin 
package that also has' a ,24-pin "piggy-back" soc- 
ket. An EPROM or ROM can be installed on the back 
of the emulator's standard 40-pin package via the 
socket (Figure A-3). A single +5 V dc power source 
is required. Figure A-4 illustrates the pinout for 
the socket carried piggyback. The socket is 
designed to accept a 2716 EPROM for the 28603 and 
a Z732 EPROM for the Z8613 device. 

Pin mnemonics and descriptions are the same as 
those for the Z8601/11 microcomputer (Chapter 6). 
Descriptions for the additional (24-pin socket) 
memory interface lines are the same as those given 
for the development devices above. 
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Pin Descriptions and Functinns 



TIMING 

AND 

CONTROL 



PORTO 

(NIBBLE < 
PROGRAMMABLE) ^ 
I/O OR A8-A15 



PORT 1 

(BYTE 

PROGRAMMABLE) 

I/O OR AD0-AD7 



PROGRAM 

MEMORY 

DATA 

INPUTS 



INTERRUPT ACKNOWLEDGE 

MEMORY DATA STROBE 

INSTRUCTION SYNC 

SYSTEM CLOCK 





+ 5V 


RESET 


R/W 


GND 


DS 




AS 


XTAL1 




XTAL2 


POo 




PO1 


P2o 


PO2 


P2l 


PO3 


P22 


PO4 


P23 


PO5 


P24 


POe 


P25 


PO7 


P26 




P27 


PI0 




PI1 


P3o 


PI2 


P3i 


PI3 P32 
PI4 "^^^ P33 


PI5 


P34 


P16 


P35 


PI7 


P36 




P37 


Do 




Di 


Ao 


D2 


Ai 


D3 


^^2 


D4 


A3 


D5 


A4 


De 


As 


D7 


Ae 




A7 


lACK 


As 


MDS 


A9 


SYNC 


A10 


SCLK 


A11 






CLOCK 



PORT 2 

(BIT PROGRAMMABLE) 



PORTS 

} SERIAL AND PARALLEL 
' I/O CONTROL 



PROGRAM MEMORY 
ADDRESS OUTPUTS 



Figure A>1. Z8612 Pin Functions 
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VccE 


1 


64 


Dp36 


XTAL2 [^ 


2 


63 


J P3i 


XTAL1 [^ 


3 


62 


3 P27 


P37C 


4 


61 


DP26 


P3o[I 


5 


60 


JP25 


RESET [2 


6 


59 


JP2. 


R/W[; 


7 


58 


JP23 


DSL 


8 


57 


1P22 


ASC 


9 


56 


JP2i 


P3sL 


10 


55 


JP20 


P32E 


11 


54 


JP33 


pooL 


12 


53 


'Jpza 


P01 \z 


13 


52 


JPI7 


PO.C 


14 


51 


J Pie 


POaC; 


'' Z8612 '° 


JPI5 


P04C 


16 


49 


IPI4 


GND ^ 


17 


48 


JPI3 


POsC 


18 


47 


JPI2 


po6[;; 


19 


46 


iPli 


P07[^ 


20 


45 


JPio 


lACK [2 


21 


44 


jDr 


SYNC[;; 


22 


43 


JO, 


scLK [[; 


23 


42 


IDs 


MDs[;; 


24 


41 


ID4 


DoC 


25 


40 


jAo 


DiC 


26 


39 


HA. 


D2[: 


27 


38 


J A. 


D3[;; 


28 


37 


:]A3 


All];;;; 


29 


36 


:]A4 


Aio[;; 


30 


35 


J As 


AsC 


31 


34 


lAe 


AaC 


32 


33 


J^r 



Figure A-2. Z8612 Pin Assignnents 
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Appendix B 
Control Registers 



Registers 



R240 SIO 
Serial I/O Register 

(FOh; Read/Write) 

I D7 I Ds I D5 I D4 I D3 I D2 I Di I Dp] 



- SERIAL DATA (Dq 



R244T0 
Counter/Timer Registe 

(F4h; Read/Write) 

|D,|D6|D5|D4|D3|D2|D,TDn 



To INITIAL VALUE (WHEN WRITTEN) 

-(RANGE: 1-256 DECIMAL 01-00 HEX) 

To CURRENT VALUE (WHEN READ) 



R241 TMR 
Timer Mode Register 

(FIh; Read/Write) 



[d7 De I D5 D4 I D3 [ D; I Di I Dp I 



Tout MODES 

NOT USED = 00 

To OUT = 01 - 

Ti OUT = 10 

INTERNAL CLOCK OUT = 11 

T|N MODES 
EXTERNAL CLOCK INPUT = 00 
GATE INPUT = 01 
TRIGGER INPUT = 10 - 
(NON-RETRIGGERABLE) 

TRIGGER INPUT = 11 
(RETRIGGERABLE) 



Lo = r 



= NO FUNCTION 
= LOADT1 



R245 PREO 
Prescaler Register 

(F5h; Write Only) 



D4 I D3 I D2 I Di I DqI 



COUNT MODE 
- = To SINGLE-PASS 
1 = To MODULON 



PRESCALER MODULO 
-(RANGE: 1-64 DECIMAL 
01-00 HEX) 



R242 Tl 
Counter Timer 1 Register 

(F2h; Read/Write) 



Dy I De I D5 I D4 I D3 I D; I D, I Dp I 



R246 P2M 
Port 2 Mode Register 

(F6h; Write Only) 

|D,|Dg|D.5|D4|D3|b;|D,|D7] 



T, INITIAL VALUE (WHEN WRITTEN) 

-(RANGE 1 256 DECIMAL 01-00 HEX) 

Ti CURRENT VALUE (WHEN READ) 



P2o-P27 I/O DEFINITION 
- DEFINES BIT AS OUTPUT 
1 DEFINES BIT AS INPUT 



R243 PREl 
Prescaler 1 Register 

(F3h; Write Only) 




R247 P3M 
Port 3 Mode Register 

(F7h; Write Only) 



li 



COUNT MODE 

= Ti SINGLE-PASS 

1 = T, MODULON 

CLOCK SOURCE 
1 = Ti INTERNAL 
= T, EXTERNAL TIMING INPUT 
(Tin) mode 

PRESCALER MODULO 
(RANGE: 1-64 DECIMAL 
01-00 HEX) 



^T^n^TO 



Lo 



P33 = INPUT P34 = OUTPUT 

-°J}P33-= INPUT P34 = DM 

11 P33 = DAV1/RDY1 P34 = RDY1/DAV1 
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Registers 

(Continued) 



R248 POIM 
Port and 1 Mode Register 

(F8h; Write Only) 



OUTPUT = 00 
INPUT = 01 
Ai2-A,5 = 1X 

EXTERNAL MEMORY TIMING 
NORMAL = 
EXTENDED = 1 



|D.|De|c 


5|d4 D 


3 1 D2 1 Di 1 Do 1 



PO0-PO3 MODE 

00 = OUTPUT 

01 = INPUT 
IX = Ag-An 

STACK SELECTION 

= EXTERNAL 

1 = INTERNAL 

>1o-Pl7 MODE 

00 = BYTE OUTPUT 

01 = BYTE INPUT 

10 = AD0-AD7 

11 = HIOmMPEDANCE AD0-AD7, 

AS, DS, R/W, A8-A11, A12-A1S 
IF SELECTED 



R252 FLAGS 
Flag Register 

(FCh; Read/Write) 

|D7|Dg|D5|D4|D3|D2|D, |d,"] 



^: 



USER FLAG F1 

USER FLAG F2 
-HALF CARRY FLAG 
-DECIMAL ADJUST FLAG 
-OVERFLOW FLAG 



R249IPR 
Interrupt Priority Register 

(F9h; Write Only) 



iDrlOfilDs |D4 DalDzJDi [Dq-] 



IRQ3, IRQ5 PRIORITY (GROUP A) 

= IRQ5 > IRQ3 - 

1 = IRQ3 > IRQ5 

IRQO, IRQ2 PRIORITY (GROUP B) 

= IRQ2 > IRQO - 

1 = IRQO > IRQ2 

IRQ1, IRQ4 PRIORITY (GROUP C) 

= IRQ1 > IRQ4 - 

1 = IRQ4 > IRQ1 



INTERRUPT GROUP PRIORITY 
RESERVED = 000 
C > A > B = 001 
- A > B > C = 010 



RESERVED = 111 



R253 RP 
Register Pointer 

(FDh; Read/Write) 

|D7[De[Ds[D,[D3|p,|D,[Do[ 

"11 

re 1 



R250 IRQ 
Interrupt Request Register 

(FAh; Read/Write) 

I D7 I De I D5 I D4 I P3 I Pa I Di I Pq I 
ERVED 1 I 



R254 SPH 
Stack Pointer 

(FEh; Read/Write) 

|d7|d6|d5|d4|d3|d2|d,|Do| 



IRQ2 = P3i INPUT 
IRQ3 = P3o INPUT, SERIAL INPUT 
IRQ4 = To, SERIAL OUTPUT 
IRQ5 = Ti 



STACK POINTER UPPER 
" BYTE (SPg-SPis) 



R251 IMR 
Interrupt Mask Register 

(FBh; Read/Write) 

{ 0; I De j D5 I D4 I D3 I Da [ D, I Dp j 



R255 SPL 
Stack Pointer 

(FFh; Read/Write) 

|D7|P6|D5|P4|P3Jd2|Pi!Po| 



- RESERVED 

-1 ENABLES INTERRUPTS 



STACK POINTER LOWER 
" BYTE (SP0-SP7) 
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Opcode 
Map 



Lower Nibble (Hex) 
6 7 8 



6,5 


6,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 


6,5 


6,5 


12/10,5 


12/10,0 


, 6,5 


12/10,0 


6,5 




DEC 


DEC 


ADD 


ADD 


ADD 


ADD 


ADD 


ADD 


LD 


LD 


DJNZ 


IR 


LD 


IP 


INC 




, Ri 


iRi 


ri, 12 


ri,Ir2 


R2,Ri 


IR2,Ri 


Ri,IM 


IRi,IM 


ri,R2 


r2,Ri 


ri,RA 


cc,RA 


ri,IM 


cc,DA 


ri. 




6,5 


6,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 
































RLC 


RLC 


ADC 


ADC 


ADC 


ADC 


ADC 


ADC 
































Ri 


IRi 


ri,r2 


ri,Ir2 


R2,Ri 


IR2,Ri 


Ri,IM 


IRi,IM 
































6,5 


6,5 


6,5 


6,5 


^ 10,5 


10,5 


10,5 


10,5 




INC 


INC 


SUB 


SUB 


SUB 


SUB 


SUB 


SUB 
































Ri 


IRi 


rx, 12 


ri,Ir2 


R2,Ri 


IR2,Ri 


Ri,IM 


IRi,IM 
































8,0 


6,1 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 




IP 


SRP 


SBC 


SBC 


SBC 


SBC 


SBC 


SBC 
































IRRi 


IM 


H,I2 


ri,Ir2 


R2,Rx 


IR2,Ri. 


Ri,IM 


IRi,IM 
































8,5 


8,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 




DA 


DA 


OR 


OR 


OR 


OR 


OR 


OR 
































Ri 


IRi 


n, 12 


ri,Ir2 


R2,Ri 


IR2,Ri 


Ri,IM 


IRi,IM 
































10,5 


10,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 




POP 


POP 


AND 


AND 


AND 


AND 


AND 


AND 
































Ri 


IR.i 


ri,r2 


ri,Ir2 


R2,Ri 


IR2,Ri 


Ri,IM 


IRi,IM 
































6,5 


6,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 




COM 


COM 


TCM 


TCM 


TCM 


TCM 


TCM 


TCM 
































Ri 


IRi 


ri, 12 


ri,Ir2 


R2,Ri 


IR2,Ri 


Ri,IM 


IRi,IM 
































10/12,1 


12/14, 1 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 




PUSH 


PUSH 


TM 


TM 


TM 


TM 


TM 


TM 
































R2 


IR2 


ri,r2 


ri, Ir2 


R2,Ri 


IR2,Ri 


Ri,IM 


IRi,IM 
































10,5 


10,5 


12,0 


18,0 










6 1 


DECW 


DECW 


LDE 


LDEI 






































DI 


RRi 


IRi 


ri,Irr2 


Iri,Irr2 






































6,5 


6,5 


12,0 


18,0 










6,1 
EI 


RL 


RL 


LDE 


LDEI 






































Ri 


IRi 


r2,Irri 


Ir2,Irri 






































10,5 


10,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 


14,0 
RET 


INCW 


INCW 


CP 


CP 


CP 


CP 


CP 


CP 






























RRi 


IRi 


ri,r2 


ri,Ir2 


R2,Ri 


IR2,Ri 


Ri,IM 


IRi,IM 






























6,5 


6,5 


6,5 


6,5 


10,5 


10,5 


10,5 


10,5 


16,0 


CLR 


CLR 


XOR 


XOR 


XOR 


XOR 


XOR 


XOR 






























IRET 


Ri 


IRi 


n, r2 


ri,Ir2 


R2,^l 


IR2,Ri 


Ri,IM 


IRi,IM 
































6,5 


6,5 


12,0 


18,0 








10,5 


6,5 
RCF 


RRC 


RRC 


LDC 


LDCI 








LD 






























Ri 


IR: 


n, Irr2 


Iri,Irr2 








ri, X, R2 






























6,5 


6,5 


12,0 


18,0 


20,0 




20,0 


10,5 


6,5 
SCF 


SRA 


SRA 


LDC 


LDCI 


CALL* 




CALL 


LD 






























Ri 


IRi 


r2,Irri 


Ir2, Irri 


IRRi 




DA 


12, X, Ri 






























6,5 


6,5 




6,5 


10,5 


10,5 


10,5 


10,5 


6,5 
CCF 


RR 


RR 




LD 


LD 


LD 


LD 


LD 






























Ri 


IRi 




ri, Ira 


R2,Ri 


IR2,Ri 


Ri,IM 


IRi,IM 






























8,5 


8,5 




6,5 




10,5 






6,0 
NOP 


SWAP 

Ri 


SWAP 

IRi 




LD 

Iri,r2 




LD 

R2,IRi 






^ 


' 


^ 


r 


1 


r 


! 


f 


} 


r 


^ 


r 


i 





Bytes per 
Instruction 



Lower 
Opcode 
Nibble 

Execution y Pipeline 

Cycles . . 4 Cycles 



Upper 
Opcode - 
Nibble 



w 



10,5 

CP 

R2,Ri 



First 
Operand 



\ 



- Mnemonic 



Second 
Operand 



Legend: 

R = 8-Bit Address 
r = 4-Bit Address 
Ri or n = Dst Address 
R2 or r2 = Src Address 

Sequence: 

Opcode, First Operand, Second Operand 

Note: The blank areas are not defined. 



*2-byte instruction; fetch cycle appears as a 3-byte instruction 
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^ZilGG 



Product Specification 



August 1988 



Supers™ MGU ROMless, 
RON, and Prototyping Device 
with EPROM Interface 



Z8800. Z8801, Z8820. Z8822 



FEATURES 

■ Improved Z8® instruction set includes multiply and 
divide instructions, Boolean and BCD operations. 

■ Additional instructions support threaded-code 
languages, such as "Forth." 

■ 325 byte registers, Including 272 general-purpose 
registers, and 53 mode and control registers. 

■ Addressing of up to 128K bytes of memory. 

■ Two register pointers allow use of short and fast 
instructions to access register groups within 600 nsec. 

■ Direct Memory Access controller (DMA). 

■ Two 16-bit counter/timers. 



Up to 32 bit-programmable and 8 byte-programmable I /O 
lines, with 2 handshake channels. 

Interrupt structure supports: 

D 27 interrupt sources 

D 16 interrupt vectors (2 reserved for future versions) 

D 8 interrupt levels 

D Servicing in 600 nsec. (1 level only) 

Full-duplex UARTwith special features. 

On-chip oscillator. 

20 MHz clock. 

8Kbyte ROM for Z8820 



GENERAL DESCRIPTION 



The Zilog Supers single-chip MCU can be used for 
development and production. It can be used as I/O- or 
memory-intensive computers, or configured to address 
external memory while still supporting many I/O lines. 



NC 

Vcc 

P06 
PO7 
P34 
P35 

AS 

DS 

P4o 

P4t 

GND 

GNO 

P42 

P43 
R/W 
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NC 
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Vcc 
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ROMIdss 
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58 


Pl6 


13 




57 


PI7 


14 




56 


P24 


15 




55 


P2s 


16 




54 


Vcc 


17 




53 


GNO 


18 


SUPERS 


52 


Vcc 


19 




51 


XTAL2 


20 




50 


XTAL1 


21 




49 


P44 


22 




48 


P45 


23 




47 


P4« 


24 




46 


P47 


?5 
26 




45 


NC 




44 




^ 


28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 ^ 



^^ 4i'4> <^ ^"^ 4^4^ 4!^<^ 4* 4^4^ie^ 4''' <{^^^^ 
Figure la. Pin Assignments — 68-pln PLCC 



The Supers features a full-duplex universal asynchronous 
receiver/transmitter (UART) with on-chip baud rate 
generator, two programmable counter /timers, a direct 
memory access (DMA) controller, and an on-chip oscillator. 

The Supers is also available as a 4S-pin and 68-pin ROMless 
microcomputer with four byte-wide I/O ports plus a 
byte-wide address /data bus. Additional address bits can be 
configured, up to a totalof 16. 
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ROMless c 
P16C 
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XTALIC 
P47C 
P22C 
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Z8801 
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3P35 
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3 GNO 
3R/W 

29 3 RESET 
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P1.C 


1 


48 


1 


POo 


p'.C 


2 


47 


J 


P01 


PLC 


3 


48 


1 


P02 


"3C: 


4 


45 


1 


P03 


"14 c 


5 


44 


J 


P04 


"1=1:: 


6 


43 


1 


P05 


PieC 


7 


42 


J 


P06 


"17 c 


8 


41 


3 


PO7 


P24C 


9 


40 


3 


P34 


P2.C 


10 


39 


J 


P35 


+5vn 


11 


38 


J 


AS 


XTAL2 [^ 


12 *'"'™ 37 


3 


DS 


XTAL1 C 


13 


36 


1 


P4o 


P4,C 


14 


35 


J 


P4i 


P4sC 


15 


34 


3 


GND 


P4,i: 


16 


33 


3 


P42 


P47C 


17 


32 


3 


P43 


P2aC 


18 


31 


3 


R/W 


P3.c: 


19 


30 


3 


RESET 


P33C 


20 


29 


3 


P36 


P^aC 


21 


28 


3 


P37 


P2.C 


22 


27 


3 


P27 


P2,C 


23 


26 


3 


P26 


P3,C 


24 


25 


3 


P3o 



TIMING 

AND 

CONTROL 



PORTO < 44 



^43. 



P0RT1 < 



PORT 4 . 



RiSlT 

R/W 

DS 

AS 

POo 

PO1 

PO2 

PO3 

PO4 

PO5 

POe 

PO7 

PI0 

PI1 

PI2 

PI3 

PI4 

PI 5 

Pl6 

PI7 

P4o 

P4i 

P42 

P43^ 




> PORTS 



PORT 4 



Figure lb. Pin Assignments — 48-pin DIP 



Figure 2. Pin Functions 



-sC 


1 




28 


3.5 


A.21: 


2 




27 


D.5 


A7C 


3 




26 


3a„ 


AeC: 


4 




25 


3AB 


AsC 


5 




24 


3 A, 


A4C: 


6 




23 


JA„ 


AaC 


7 


PROTO- 
PACK 


22 


Joe 


A2r 


8 


EPROM 


21 


J A,o 


AlC 


g SOCKET 


20 


Dei 


AoC 


10 




19 


JD, 


DoC 


11 




18 


Doe 


DlC 


12 




17 


Jo, 


D2L: 


13 




16 


Hd, 


gndC 


14 




15 


J 03 



DATA< 



POWER 



e 



Dp 

Di 

D2 

D3 

D4 

D5 

D6 

D7 

OE 

CE 

GND 

+ 5V 

+ 5V 

+ 5V 



PROTOPACK 
EPROM 
SOCKET 



Ao 
Ai 
A2 
A3 
A4 
As 
Ae 
A7 
As 
A9 
A10 
A11 
A12 

Al3 



> ADDRESS 



Figure 3. Pin Assignments— 28-Pin Piggybacl( Socltet 



Figure 4. Pin Functions— 28-Pin Piggybacl( Soclcet 



Protopacl( 

This part functions as an emulator for the basic 
microcomputer. It uses the same package and pin-out as 
the basic microcomputer but also has a 28-pin " piggy back" 
socket on the top into which a ROM or EPROM can be 
installed. The socket is designed to accept a type 2764 
EPROM. 

This package permits the protopackto be used in prototype 
and final PC boards while still permitting user program 



development. When a final program is developed, it can be 
mask-programmed into the production microcomputer 
device, directly replacing the emulator. The protopack part 
is also useful in situations where the cost of mask- 
programming is prohibitive or where program flexibility is^ 
desired. 
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I/O 
(BIT PROGRAMMABLE) 



XTAL AS DS R/W RESET 

It t t t 1 




tttttttt lltttttt 



I/O 

(BIT PROGRAMMABLE) 

OR CONTROL 



ADDRESS OR I/O 
(BIT PROGRAMMABLE) 



ADDRESS/DATA OR I/O 
(BYTE PROGRAMMABLE) 



Z-BUS WHEN USED AS 
ADDRESS/DATA BUS 



Figure 5. Functional Block Diagram 



ARCHITECTURE 



The Supers architecture includes 325 byte-wide internal 
registers. 272 of these are available for general purpose 
use; the rennaining 53 provide control and mode functions. 

The instruction set is specially designed to deal with this 
large register set. It includes a full complement of 8-bit 
arithmetic and logical operations, including multiply and 
divide instructions and provisions for BCD operations. 
Addresses and counters can be incremented and 
decremented as 16-bit quantities. Rotate, shift, and bit 
manipulation instructions are provided. Three new 
instructions support threaded-code languages. 



The UART is a full-function multipurpose asynchronous 
serial channel with many premium features. 

The 16-bit counters can operate independently or be 
cascaded to perform 32-bit counting and timing operations. 
The DMA controller handles transfers to and frorr;! the 
register file or memory. DMA can use the UART or one of two 
ports with handshake capability. 

The architecture appears in the block diagram (Figure 5). 



PIN DESCRIPTIONS 



The Supers connects to external devices via the following 
TTL-compatible pins: 

AS. Address Strobe (output, active Low). AS is pulsed 
Low once at the beginning of each machine cycle. The 
rising edge indicates that addresses R/W and DM, when 
used, are valid. 

DS. Da fa Strobe (output, active Low). DS provides timing 
for data movement between the address/data bus and 
external memory During write cycles, data output is valid at' 
the leading edge of DS. During read cycles^ data input 
must be valid prior to the trailing edge of DS. 



POo-POy, P1o-Pl7, P2o-P27, P3o-P37, P4o-P47. Port I/O 
Lines (input/output). These 40 lines are divided into five 8-bit 
I/O ports that can be configured under program control for 
I/O or external memory interface. 

In the ROMIess devices, Port,1 is dedicated as a 
multiplexed address/data port, and Port pins can be 
assigned as additional address lines; Port non-address 
pins may be assigned as I/O. In the ROM and protopack. 
Port 1 can be assigned as input or output, and Port can be 
assigned as input or output on a bit by bit basis. 
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Ports 2 and 3 can be assigned on a bit-for-bit basis as 
general I/O or interrupt lines. They can also be used as 
special-purpose I/O lines to support the UART, 
counter/timers, or handshake channels. 

Port 4 is used for general I/O. 

During reset, all port pins are configured as inputs (high 
impedance) except for Port 1 and Port in the ROMIess 
devices. In these, Port 1 is configured as a multiplexed 
address/data bus, and Port pins PO0-PO4 are configured 
as address out, while pins PO5-PO7 are configured as inputs. 



RESET. f?esef (input, active Low). Reset initializes and starts 
the Supers. When it is activated, it halts all processing; when 



it is deactivated, the SuperS begins processing at address 
0020h. 

ROMIess. (input, active High). This input controls the 
operation mode of a 68-pin Supers. When connected to Vcc. 
the part will function as a ROMIess ZSSOO. When connected 
to GND, the part will function as a ZS820 ROM part. 

R/W. Read/Write (output). R/W determines the direction of 
data transfer for external memory transactions. It is Low 
when writing to program memory or data memory, and High 
for everything else. 

'XTAL1, XTAL2. (Crystal oscillator input.) These pins 
connect a parallel resonant crystal or an external clock 
source to the on-board clock oscillator and buffer 



REGISTERS 



The Supers contains a 256-byte internal register space. 
However, by using the upper 64 bytes of the register space 
more than once, a total of 325 registers are available. 

Registers from 00 to BF are used only once. They can be 
accessed by any register command. Register addresses CO 
to FF contain two separate sets of 64 registers. One set, 
called control registers, can only be accessed by register 
direct commands. The other set can only be addressed by 
register indirect, indexed, stack, and DMA commands. 



The uppermost 32 register direct registers (EO to FF) are 
further divided into two banks (0 and 1), selected by the 
Bank Select bit in the Flag register When a Register Direct 
command accesses a register between EO and FF, it looks at 
the Bank Select bit in the Flag register to select one of the 
banks. 

The register space is shown in Figure 6. 



EOh 
DFh 



DOh 
CFh 



MODE AND .^ 

CONTROL REGISTERS 
(REGISTER ADDRESSING ONLY) 



SYSTEM REGISTERS: 

STACK, FLAGS, PORTS, ETC. 

(REGISTER ADDRESSING ONLY) 



WORKING REGISTERS 
(WORKING REGISTER 
ADDRESSING ONLY) 



DATA REGISTERS 

(INDIRECT REGISTER, INDEXED, 

STACK OR DMA 

ACCESS ONIIY) 



4^ DATA REGISTERS ^ 

(ALL ADDRESSING MODES) 



192 
BYTES 



Figure 6. Supers Registers 
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Working Register Window 

Control registers R214 and R215 are the register pointers, 
RPO and RP1. They each define a moveable, 8-register 
section of the register space. The registers within these 
spaces are called working registers. 

Working registers can be accessed using short 4-bit 
addresses. The process, shown in section a of Figure 4, 
works as follows: 

■ The high-order bit of the 4-bit address selects one of the 
two register pointers (0 selects RPO; 1 selects RP1). 

■ The five high-order bits in the register pointer select an 
8-register (contiguous) slice of the register space. 

■ The three low-order bits of the 4-bit address select onfe of 
the eight registers in the slice. 



The net effect is to concatenate the five bits fronn the register 
pointer to the three bits fronn the address to form an 8-bit 
address. As long as the address in the register pointer 
remains unchanged, the three bits from the address will 
always point to an address within the same eight registers. 

The register pointers can be moved by changing the five 
high bits in control registers R21 4 for RPO and R21 5 for RP1 . 

The working registers can also be accessed by using full 
8-bit addressing. When an 8-bit logical address in the range 
192 to 207 (CO to CF) is specified, the lower nibble is used 
similarly to the 4-bit addressing described above. This is 
shown in section b of Figure 7. 



rl 



RP0(R214) 
RP1 (R215) 



SELECTS 
RP0ORRP1 



ADDRESS OPCODE 



I 4-BIT ADDRESS PROVIDES 3 LOW-ORDER BITS 



REGISTER POINTER PROVIDES 
5 HIGH-ORDER BITS 



TOGETHER THEY CREATE 
8-BIT REGISTER ADDRESS 



^_JL_ 


J 


1 



SELECTS 
RPO OR RP1 



RP0(R214) 
RP1(R215) 



8-BIT 

LOGICAL ADDRESS 



REGISTER POINTER PROVIDES 
5 HIGH-ORDER BITS 



3 LOW-ORDER BITS 



8-BIT PHYSICAL ADDRESS 



a. 4-Bit Addressing 



b. 8-Bit Addressing 



Figure 7. Working Register Window 
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Since any direct access to logical addresses 192 to 207 
involves the register pointers, the physical registers 192 to 
207 can be accessed only when selected by a register 
pointer After a reset, RPO points to R1 92 and RP1 points to 
R200. 



Register List 

Table 1 lists the SuperS registers. For more details, see 
Figures. 



Tabie 1 . Super-8 Registers 



Address 



Decimal 



IHexadecimal 



i\/lnemonic 



Function 



Generai-Purpose Registers 

000-192. 00-BF 

192-207 CO-CF 

192-255 CO-FF 



General purpose (all address modes) 
Working register (direct only) 
General purpose (indirect only) 



l\/lode and Control Registers 

208 
209 
210 
211 
212 
213 
214 
215 
216 
■217 
218 
219 
220 
221 
222 
224 



225 

226 

227 

228 

229 

235 
236 
237 
239 
240 

241 

244 
245 
246 
247 
248 



DO 




PO 


D1 




PI 


D2 




P2 


D3 




P3 


D4 




P4 


D5 




FLAGS 


D6 




RPO 


D7 




RP1 


D8 




SPH 


D9 




SPL 


DA 




IPH 


DB 




IPL 


DC 




IRQ 


DD 




IMR 


DE 




SYM 


EO 


BaiikO 


COCT 




Banki 


COM 


El 


BankO 


C1CT 




Banki 


C1M 


E2 


BankO 


COCH 




Banki 


CTCH 


E3 


BankO 


COCL 




Banki 


CTCL 


E4 


BankO 


C1CH 




Banki 


C1TCH 


E5 


BankO 


C1CL 




Bank 1 


C1TCL 


EB 


BankO 


UTC 


EC 


BankO 


URC 


ED 


BankO 


UIE 


EF 


BankO 


UIO 


FO 


BankO 


POM 




Banki 


DCH 


F1 


, BankO 


PM 




Banki 


DCL 


F4 


BankO 


HOC 


F5 


BankO 


H1C 


F6 


BankO 


P4D 


F7 


Bank 


P40D 


F8 


BankO 


P2AM 




Banki 


UB'GH 



Port I/O bits 

Port 1 (I/O only) 

Port 2 

Ports 

Port 4 ' 

System Flags Register 

Register Pointer 

Register Pointer 1 

Stack Pointer High Byte 

Stack Pointer Low Byte 

Instruction Pointer High Byte 

Instruction Pointer Low Byte 

Interrupt Request 

Interrupt Mask Register 

System Mode 

CTR Control 

CTR Mode 

CTR 1 Control 

CTR 1 Mode 

CTR Capture Register, bits 8-15 

CTR Timer Constant, bits 8-1 5 

CTR Capture Register, bits 0-7 

CTR Time Constant, bits 0-7 

CTR 1 Capture Register, bits 8-15 

CTR 1 Time Constant, bits 8-1 5 

CTR 1 Capture Register, bits 0-7 

CTR 1 Time Constant, bits 0-7 

UART Transmit Control 

DART Receive Control 

UART Interrupt Enable 

UART Data 

Port Mode 

DMA Count, bits 8-1 5 

Port Mode Register 

DMA Count, bits 0-7 

Handshake Channel Control 

Handshake Channel 1 Control 

Port 4 Direction 

Port 4 Open Drain 

Port 2/3 A Mode 

UART Baud Rate Generator, bits 8-1 5 
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Table 1 . Super-8 Registers (Continued) 




Address 










Decimal 




Hexadecimal 


Mnemonic 


Function 


Mode and Control Registers (Continued) 






249 




F9 


BankO 


P2BM 


Port 2/3 B Mode 








Bank1 


UBGL 


UART Baud Rate Generator, bits 0-7 


250 




FA 


BankO 


P2CM 


Port 2/3 C Mode 








Bank1 


UMA 


UART Mode A 


251 




FB 


BankO 


P2DM 


Port 2/3 D Mode 








Bank1 


UMB 


UART Mode B 


252 




FC 


BankO 


P2AIP 


Port 2/3 A Interrupt Pending 


253 




FD 


BankO 


P2BIP 


Port 2/3 B Interrupt Pending 


254 




FE 


BankO 


EMT 


External Memory Timing 








Bank1 


WUMCH 


Wakeup Match Register 


255 




FF 


BankO 


IPR 


Interrupt Priority Register 








Bank1 


WUMSK 


Wakeup Mask Register 



MODE AND CONTROL REGISTERS 



R213(D5) FLAGS 
SYSTEM FLAGS REGISTER 



CARRY FLAG 

ZERO FLAG 

SIGN FLAG 

OVERFLOW FLAG 



J 



Ds 



R214(D6)RP0 
REGISTER POINTER 



R215(D7)RP1 
REGISTER POINTER 1 



D3 



L 



BANK ADDRESS 
FAST INTERRUPT STATUS 
HALF-CARRY FLAG 
DECIMAL ADJUST 



Do 



R218(dA)IPH 
INSTRUCTION POINTER HIGH 



d7| 



-HIGHBYTE(IP8-IP15) 



R219(DB)IPL 
INSTRUCTION POINTER LOW 



-LOW BYTE (IP0-IP7) 



R220(DC)IRQ 
INTERRUPT REQUEST (READ ONLY) 


|d7 De 


D. 


0. 


0, 


0. 


Di Do 1 


LEVEL 7 -J 












_ 


LEVEL 6 ' 












1 


LEVEL 5 1 










LEVEL 4 




— 


_ 


_J 






L 






_ 






LEVEL 
LEVEL 1 
LEVEL 2 
LEVEL 3 



R216(D8)SPH 
STACK POINTER 



D2 



R217(D9)SPL 
STACK POINTER 



06 



-HIGHBYTE(SP8-SP15) 



-LOW BYTE (SP0-SP7) 



E 



LEVEL 
LEVEL 6 
LEVEL 5 
LEVEL 4 



J 



R221 (DD) IMR 
INTERRUPT MASK 



L 



LEVEL 
LEVEL 1 
LEVEL 2 
LEVEL 3 



Figure 8. Mode and Control Registers 
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MODE AND CONTROL REGISTERS (Continued) 



R222(DE)SYM 
SYSTEM MODE 



F 



Da 



Di Do 




= GLOBAL INTERRUPT ENABLE 



= FAST INTERRUPT ENABLE 



FAST INTERRUPT SELECT 



000 


LEVEL 


001 


LEVEL 1 


010 


LEVEL 2 


oil 


LEVELS 


100 


LEVEL 4 


101 


LEVEL 5 


110 


LEVELS 


111 


LEVEL? 



R224,BANK0(E0)C0CT 
COUNTER CONTROL 



= SINGLE CYCLE 
= CONTINUOUS 



J 



= COUNT DOWN - 
1 = COUNT UP 

1 = LOAD COUNTER - 

1 = SOFTWARE TRIGGER - 



D7 De D5 D4 D3 D2 Di Do 



L. 



ENABLE COUNTER 



READ1 = END OF COUNT 
" WRITE 1 = RESET END OF COUNT 

- 1 = ZERO COUNT INTERRUPT ENABLE 

- 1 = SOFTWARE CAPTURE 



INPUT PIN ASSIGNMENTS: 



R224 BANK 1(E0) COM 
COUNTER MODE 



I D7 De D5 D4 D3 D2 Di Do I 



D7 De D5 D4 


P27 


P26 











I/O 


I/O 










I/O 


TRIGGER 





1 





GATE 


I/O 





1 




GATE 


TRIGGER 


1 








I/O 


CO INPUT 


1 







TRIGGER 


CO INPUT 


1 


1 





GATE 


CO INPUT 


1 


1 




GATE/ 
TRIGGER 


CO INPUT 


1 








CO OUTPUT 


I/O 


1 







CO OUTPUT 


TRIGGER 


1 


1 





CO OUTPUT 


GATE 


1 


1 




CO OUTPUT 


GATE/TRIGGER 


1 1 








CO OUTPUT 


CO INPUT 



1 

1 1 



- UNDEFINED - 



"C 



CAPTURE MODE: 

00 = NO CAPTURE 

01 = CAPTURE ON RISING 

EDGE0FP2Z 

10 = BI-VALUEMODE 

11 = CAPTURE ON BOTH 

EDGES OF P27 

= EXTERNAL 

UP/DOWN CONTROL P27 

1 = PROGRAMMED 

UP/DOWN CONTROL 

1 = ENABLE RETRIGGER 



- CASCADE COUNTERS - 



R225BANK0(E1)C1CT 
COUNTER 1 CONTROL 



P7 De 



= SINGLE CYCLE 
= CONTINUOUS 



J 



= COUNT DOWN - 



= LOAD COUNTER - 



1 = SOFTWARE TRIGGER - 



Di I Dp I 



ENABLE COUNTER 



READ1 = END OF COUNT 
' WRITE 1 = RESET END OF COUNT 

- 1 = ZERO COUNT INTERRUPT ENABLE 

- i = SOFTWARE CAPTURE 



Figure 8. Mode and Control Registers (Continued) 
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MODE AND CONTROL REGISTERS (Continued) 



R225BANK1(E1)C1M 
COUNTER 1 MODE 



E 


De 


Ds 


04 


03 


02 


Di 


3 



INPUT PIN ASSIGNMENTS 




Or 06 Ds 04 P37 


P36 








I/O 


I/O 





1 


I/O 


TRIGGER 


1 





GATE 


I/O 


1 


1 


GATE 


TRIGGER 


1 





I/O 


CO INPUT 


1 


1 


TRIGGER 


CO INPUT 


1 1 





GATE 


CO INPUT 


1 1 


1 


GATE/ 








TRIGGER 


CO INPUT 


1 





CO OUTPUT 


I/O 


1 


1 


CO OUTPUT 


TRIGGER 


1 1 





CO OUTPUT 


GATE 


1 1 


1 


CO OUTPUT 


GATE/TRIGGER 


1 1 





CO OUTPUT 


CO INPUT 



- UNDEFINED - 



i: 



CAPTURE MODE: 

00 rr NO CAPTURE 

01 r: CAPTURE ON RISING 

EDGEOFP37 

10 = BI-VALUEMODE 

11 = CAPTURE ON BOTH 

EDGES OF P37 

= EXTERNAL 

UP/DOWN CONTROL PSy 

1 = PROGRAMMED 

UP/DOWN CONTROL 

1 = ENABLE RETRIGGER 



R226BANK0(E2)C0CH 
COUNTER CAPTURE 



[o, 


06 


05 


D4 


D, 


02 


Oi 


^ 















HIGH BYTE (COCa-COC^is) 



E 



R229BANK0(E5)C1CL 
COUNTER 1 CAPTURE 



LOWBYTE(C1Co-C1C7) 



R226 BANK 1 (E2) COTCH 
COUNTER TIME CONSTANT 



E 



04 



Do 



■ HIGHBYTE(C0TC8-C0TCi5) 



R229BANK1(E5)C1TCL 
COUNTER 1 TIME CONSTANT 



0? Pe Ds D4 O3 D2 Di Do I 



■ LOWBYTE(ClTCo-ClTC7) 



R227BANK0(E3)C0CL 
COUNTER CAPTURE 



K 


06 


D5 


04 


Da 


02 


Di 


3 



R235 BANK (EB) UTC 
UART TRANSMIT CONTROL 



E 



■ LOW BYTE (COC0-COC7) 



TRANSMIT DATA SELECT: 

= OUTPUT P3i DATA 

1 = OUTPUT TRANSMIT DATA 



J 



R227BANK1(E3)C0TCL 
COUNTER TIME CONSTANT 


I 


[07 06 


Ds 


D4 


03 


D2 


Di 


id 



STOP BITS: - 
= 1 STOP BIT 
1 = 2 STOP BITS 

1 = WAKE-UP ENABLE - 



• LOW BYTE (COTC0-COTC7) 



Ds 



d7] 



TRANSMIT DMA ENABLE 
TRANSMIT BUFFER EMPTY 
ZERO COUNT 
TRANSMIT ENABLE 



R228BANK0(E4)C1CH 
COUNTER 1 CAPTURE 



■ HIGHBYTE(C1C8-C1Ci5) 



R228-SANK1(E4)C1TCH 
COUNTER 1 TIME CONSTANT 



1 = WAKE-UP DETECT 

1 = CONTROL CHARACTER DETECT 

1 = BREAK DETECT 

1 = FRAMING ERROR 



J 



R236BANK0(EC)URC 
UART RECEIVE CONTROL 



K 


De 


Ds 


D4 


0^3 


02 


Di 


3 



- HIGH BYTE (CITCs-CITCis) 



Dl I Do I 



u_ 



RECEIVE CHARACTER 
AVAILABLE 

- 1 = RECEIVE ENABLE 

- 1 = PARITY ERROR 

- 1 = OVERRUN ERROR 



Figure 8. Mode and Control Registers (Continued) 
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MODE AND CONTROL REGISTERS (Continued) 



R237BANK0(ED)UIE 
UART INieRRUPT ENABLE 



[d? |D6 



1 =: WAKE-UP INTERRUPT ENABLE 



J 



1 = CONTROL CHARACTER - 

INTERRUPT ENABLE 

: BREAK INTERRUPT ENABLE - 



= RECEIVE ERROR INTERRUPT - 
ENABLE 



Di Do 



L, 



= RECEIVE CHARACTER AVAILABLE 

INTERRUPT ENABLE 
= RECEIVE DMA ENABLE 



• 1 = TRANSMIT INTERRUPT ENABLE 
■ 1 = ZERO COUNT INTERRUPT ENABLE 



R239BANK0(EF)UIO 

UART TRANSMIT DATA (WRITE) 

UART RECEIVE DATA (READ) 



E 



De 



D4 



- DATA (Do - LSB) 



R240 BANK 0(F0) POM 
PORTO MODE 



P7 De 



POr MODE 
POe MODE 
POs MODE 



J 



PO4 MODE - 



L 



POo MODE 
PO1 MODE 
PO2 MODE 



- PO3 MODE 



= I/O; 1 = ADDRESS 



R240 BANK 1 (FO) DCH 
DMA COUNT 



E 



D5 



R244 BANK 0(F4) HOC 
HANDSHAKE CONTROL (WRITE ONLY) 



Di Do 



DESKEW COUNTER - 



,L,= 



HANDSHAKE ENABLE 



• PORT SELECT: 
1 = PORT 1; = PORT 4 



- DMA ENABLE: 



1 = ENABLED 

= DISABLED 

- MODE: 

1 = FULLY INTERLOCKED 
= STROBED 



R245BANK0(F5)H1C 
HANDSHAKE 1 CONTROL (WRITE ONLY) 



DESKEW COUNTER 
(RANGE 1-16) 



- HIGHBYTE(DC8-DCi5) 



E 



D3 



Di Do 



L, 



HANDSHAKE ENABLE 
NOT USED 



1 = FULLY INTERLOCKED 
= STROBED 



R246BANK0(F6)P4D 
PORT 4 DIRECTION 



Do 



D5 



D3 



Pol 



-P40-P47 I/O DIRECTION 
= OUTPUT; 1 = INPUT 



R241BANK0(F1)PM 
PORT MODE (WRITE ONLY) 



D7 Do D5 D4 D3 D2 Di Do 



J 



PORT 1 MODE 

00 I OUTPUT 

01 INPUT. 

IX I ADDRESS/DATA 



R241BANK1(F1)DCL 
DMA COUNT 



D7 De D5 D4 D3 D2 Di Do 



L 



PORT DIRECTION 

= OUTPUT 

1 = INPUT 
-OPEN-ORAIN PORTO 

= PUSH-PULL 

1 = OPEN-DRAIN 

- OPEN DRAIN PORT 1 

= PUSH-PULL 

1 = OPEN-DRAIN 

- ENABLE DM P35 

= DISABLE 

1 = ENABLE 



- LOW BYTE (DCo-DC7) 



R247BANK0(F7)P4OD 
PORT 4 OPEN-DRAIN 



D7 Dfi D5 D4 D3 D2 Di Do 



P40-P47 OPEN-DRAIN 
~0 = PUSH-PULL; 1 = OPEN-DRAIN 



P3l MODE 
PSoMODE 



R248BANK0(F8)P2AM 
PORT 2/3 A MODE (WRITE ONLY) 


|o. 


Oe 


0. 


D4 


D3 1 D2 1 Di 1 Do 1 












1 



P2oMODE 
P2i MODE 



INPUT 

INPUT, INTERRUPT ENABLED 
OUTPUT, PUSH-PULL 
OUTPUT, OPEN-DRAIN 



Figure 8. Mode and Control Registers (Continued) 
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MODE AND CONTROL REGISTERS (Continued) 



R248 BANK 1 (F8) UBGH 
UART BAUD-RATE GENERATOR 



Ds 



- HIGH BYTE(UBG8-UBGi5) 



R2S0BANK0(FA)P2CM 
PORT 2/3 C MODE (WRITE ONLY) 



Dr De Ds 



P3s MODE 
P34 MODE 



zr 



D3 



D2 Dl Do 



1Z 



P24MODE 
P25MODE 



P32 MODE 



R249BANK0(F9)P2BM 
PORT 2/3 B MODE (WRITE ONLY) 


1 D7 1 De 1 Ds 


D4 


03 


D2 1 Dl 1 Do 1 








ODE 1 






I 



P22MODE 

P23 MODE 



INPUT 

INPUT, INTERRUPT ENABLED 
OUTPUT, PUSH-PULL 
OUTPUT, OPEN-DRAIN 



Rr.49 BANK 1 (F9) UBGL 
UART BAUD-RATE GENERATOR 



Dr 



De D5 



D3 



D2 Dl 



- LOW BYTE (UBG0-UBG7) 



INPUT 

INPUT, INTERRUPT ENABLED 
OUTPUT, PUSH-PULL 
OUTPUT, OPEN-DRAIN 



R250 BANK 1 (FA) UMA 
UART MODE A 



D7 De D5 



CLOCK RATE 


D7D6 
=X1 

1 =X16 

1 =X32 
1 1 =X64 


BITS PER CHARACTER 


D5D4 






1 

1 
1 1 


= 5 BITS 
= 6 BITS 
= 7 BITS 
= 8 BITS 



_J 



D4 D3 D2 Dl Do I 



L 



TRANSMIT WAKE-UP VALUE 
RECEIVE WAKE-UP VALUE 
1 = EVEN PARITY 
1 = PARITY ENABLE 



R251BANK0(FB)P2DM 
PORT 2/3 D MODE (WRITE ONLY) 





^ 


De 


D5 


D4 


D3 D2 Dl Do 


P37 MODE 









1 P26 MODE 


' 








)0 

)t 


1 


INPUT 
INPUl 
OUTP 
OUTP 


,iNT 
UT,P 
UT,0 


JSH- 
PEN- 


PT ENABLED 

PULL 

DRAIN 



R251BANK1(FB)UMB 
UART MODE B 



E 



CLOCK OUTPUT SELECT 

D7D6 

=P2iDATA 

1 = SYSTEM CLOCK (XTAU2) 

1 = BAUD-RATE GENERATOR 

OUTPUT 
1 1 = TRANSMIT DATA CLOCK 

1 = AUTO-ECHO - 



3 



RECEIVE CLOCK INPUT SELECT: - 

= P2o 

1 = BAUD-RATE GENERATOR 

OUTPUT 



D2 



D1 I Do I 



L, 



LOOPBACK ENABLE 

- 1 = BAUD-RATE GENERATOR ENABLE 

- BAUD-RATE GENERATOR SOURCE: 

= P2o (EXTERNAL) 

1 = INTERNAL (XTAL/4) 

TRANSMIT CLOCK INPUT SELECT: 

i=P2i 

1 = BAUD-RATE GENERATOR OUTPUT 



Figure 8. Mode and Control Registers (Continued) 
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MODE AND CONTROL REGISTERS (Continued) 



R252BANK0(FC)P2AIP 
PORT 2/3 A INTERRUPT PENDING (READ ONLY) 



I D7 De D5 D4 O3 D2 O1 Do I 



P33 
P32 
P23 
P22 



J 



L 



P2o 
P2i 
P3o 
P3i 



R253 BANK (FD).P2 BIP 
PORT 2/3 B INTERRUPT PENDING (READ ONLY) 



I D7 De D5 D4 Da D2 Di Do I 



P37 
P3o 
P27 
P26 



J 



L 



P24 
P25 
P34 
P35 



R254 BANK 1 (FE) WUMCH 
WAKE-UP MATCH REGISTER 



D5 D4 D3 D2 



Do 



- THIS BYTE, MINUS MASKED BITS, 
IS USED FOR WAKE-UP MATCH 



R255BANK0(FF)IPR 
INTERRUPT PRIORITY REGISTER 



[dT De 



D5 D4 D3 D2 Di 



GROUP PRIORITY - 



D7 D4 Di 



= UNDEFINED 

=:B>C>A 

= A>B>C 
=B>A>C 
=C>A>B 
=C>B>A 
= A>C>B 
= UNDEFINED 



|do| 



J L 



GROUP A 

= IRQO > IRQ1 

1 = IRQ1 > IRQO 

- GROUP B 

= IRQ2 > (IRQ3,IRQ4) 

1 = (IRQ3,IRQ4) > IRQ2 

- SUBGROUP B 

= IRQ3 > IRQ4 

1 = IRQ4 > IRQ3 

- GROUP C 

= IRQ5>(IRQ6,IRQ7) 

1 =(IRQ6,IRQ7)>IRQ5 

- SUBGROUP C 

= IRQ6 > IRQ7 

1 = IRQ7 > IRQ6 



R254BANK0(FE)EMT 
EXTERNAL MEMORY TIMING REGISTER 



Do| 



L 



DMA SELECT: 

= REGISTER FILE 

1 = DATA MEMORY 

■ STACK SELECT: 

= REGISTER FILE 

1 = DATA MEMORY 

• DATA MEMORY AUTOMATIC WAITS 

00 = NO WAITS 

01 = 1 WAIT 

10 = 2 WAITS 

11 =3 WAITS 



■ PROGRAM MEMORY AUTOMATIC WAITS 

00 = NO WAITS 

01 = 1 WAIT 

10 = 2 WAITS 

11 =3 WAITS 

• SLOW MEMORY TIMING 

= DISABLED 

1 = ENABLED 

- EXTERNAL WAIT INPUT 

= P34 IS NORMAL I/O 

1 = P34 IS EXTERNAL WAIT INPUT 



R255 BANK 1 (FF) WUMSK 
WAKE-UP MASK REGISTER 



D7 De D5 D4 D3 D2 Di Do 



- THESE BITS CORRESPOND TO BITS 
IN WAKE-UP MATCH REGISTER; Os 
MASK CORRESPONDING MATCH BITS 



Figure 8. Mode and Control Registers (Continued) 
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I/O PORTS 



Portl 



The Supers has 40 I/O lines arranged into five 8-bit ports. 
These lines are all TTL-compatible, and can be configured 
as inputs or outputs. Some can also be configured as 
address/data lines. 

Each port has an input register, an output register, and a 
register address. Data coming into the port is stored in the 
input register, and data to be written to a port is stored in the 
output register Reading a port's register address returns the 
value in the input register; writing a port's register address 
loads the value in the output register If the port is configured 
for an output, this value will appear on the external pins. 

When the CPU reads the bits configured as outputs, the 
data on the external pins is returned. Under normal output 
Iqading, this has the same effect as reading the output 
register, unless the bits are configured as open-drain 
outputs. 

The ports can be configured as shown in Table 2. 
Table 2. Port Configuration 



Port 



Configuration Choices 



Address outputs and/or general I/O 

1 Multiplexed address/data(or I/O, only for ROM 
and Protopack) 

2 and 3 Control I/O for UART handshake channels, and 

counter/timers; also general I/O and external 
interrupts 
4 General I/O 



Porto 

Port can be configured as an I/O port or an output for 
addressing external memory, or it can be divided and used as 
both. The bits configured as I/O can be either all outputs or all 
inputs; they cannot be mixed. If configured for outputs, they 
can be push-pull or open-drain type. 

Any bits configured for I/O can be accessed via R208. To write 
to the port, specify R208 as the destination (dst) of an 
instruction; to read the port, specify R208 as the source (src). 

Port bits configured as I/O can be placed under handshake 
control of handshake channel 1 . 

Port bits configured as address outputs cannot be accessed 
via the register 

In ROMIess devices, initially the four lower bits are configured 
as address eight through twelve. 



In the ROMIess device, Port 1 is configured as a byte-wide 
address/data port. It provides a byte-wide multiplexed 
address/data path. Additional address lines can be added 
by configuring Port 0. , 

The ROM and Protopack Port 1 can be configured as above 
or as an I/O port; it can be a byte-wide input, open-drain 
output, or push-pull output. It can be placed under 
handshake control or handshake channel 0. 

Ports 2 and 3 

Ports 2 and 3 provide external control inputs and outputs for 
the UART handshake channels, and counter/timers. The 
pin assignments appear in Table 3. 

Bits not used for control I/O can be configured as 
general-purpose I/O lines and/or external interrupt inputs. 

Those bits configured for general I/O can be configured 
individually for input or output. Those configured for output 
can be individually configured for open-drain or push-pull 
output. 

All Port 2 and 3 input pins are Schmitt-triggered. 

The port address for Port 2 is R21 0, and for Port 3 is R211 . 

Table 3. Pin Assignments for Ports 2 and 3 



Port2 


Port 3 


Bit Function 


Bit 


Function 


UART receiveclock 





UART receive data 


1 UART transmit clock 


1 


UART transmit data 


2 Reserved 


2 


Reserved 


3 Reserved 


3 


Reserved 


4 Handshake input 


4 


Handshake 1 input/WAIT 


5 Handshake output 


5 


Handshake 1 output/DM 


6 Counter input 


6 


Counter 1 input 


7 Counter I/O 


7 


Counter 1 I/O 



Port 4 

Port 4 can be configured as I/O only. Each bit pan be 
configured individually as input or output, with either 
push-pull or open-drain outputs. All Port 4 inputs are 
Schmitt-triggered. 

Port 4 can be placed under handshake control of 
handshake channel 0. Its register address is R21 2. 
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UART 

The UART is a full-duplex asynchronous 'channel. It 
transmits and receives independently with 5 to 8 bits per 
character, has options for even or odd bit parity, and a 
wake-up feature. 

Data can be read into or out of the UART via R239, Bank 0. 
This single address is able to serve a full-duplex channel 
because it contains two complete 8-bit registers— one for 
the transmitter and the other for the receiver 

Pins 

The UART uses the following Port 2 and 3 pins: 



Port/Pin 

2/0 
3/0 
2/1 
3/1 



UART Function 

Receive Clock 
Receive Data 
Transmit Clock 
Transmit Data 



Transmitter 

When the UART's register address is specified as the 
destination (dst) of an operation, the data is output on the 
UABT which automatically adds the start bit, the 
programmed parity bit, and the programmed number of 
stop bits. It can also add a wake-up bit if that option is 
selected. 

If the UART is programmed for a 5-, 6-, or 7-bit character, the 
extra bits in R239 are ignored. 

Serial data is transmitted at a rate equal to t, 1/16, 1/32 or 
1/64 of the transmitter clock rate, depending on the 
programmed data rate. All data is sent out on the falling 
edge of the dock input. 

When the UART has no data to send, it holds the output 
marking (High). It may be programmed with the Send Break 
command to hold the output Low (Spacing), which it 
continues until the command is cleared. 



Receiver 

The UART begins receive operation when Receive Enable 
(URC, bit 0) is set High. After this, a Low on the receive input 
pin for longer than half a bit time is interpreted as a start bit. 
The UART samples the data on the input pin in the middle of, 
each clock cycle until a complete byte is assembled. This is 
placed in the Receive Data register 

If the 1 X clock mode is selected, external bit synchronization 
must be provided, and the input data is sampled on the 
rising edge of the clock. 

For character lengths of less than eight bits, the UART 
inserts ones into the unused bits, and, if parity is enabled, 
the parity bit is not stripped. The data bits, extra ones, and 
the parity bit are placed in the UART Data register (UIO). 

While the UART is assembling a byte in its input shift register, 
the CPU has time to service an interrupt and manipulate the 
data character in UIO. 

Once a complete character is assembled, the UART checks 
it and performs the following: 

■ If it is an ASCII control character, the UART sets the 
Control Character status bit. 

■ It checks the wake-up settings and completes any 
indicated action. 

■ If parity is enabled, the UART checks to see if the 
calculated parity matches the programmed parity bit. If 
they do not match, it sfets the Parity Error bit in URC 
(R236 Bank 0), which remains set until reset by software. 

■ It sets the Framing Error bit (URC, bit 4) if the character is 
assembled without any stop bits. This bit remains set until 
cleared by software. 

Overrun errors occur when characters are received faster 
than they are read. That is, when the UART has assembled a 
complete character before the CPU has read the current 
character, the UART sets the Overrun Error bit (URC, bit 3), 
and the character currently in the receive buffer is lost. 

The overrun bit remains set until cleared by software. 
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ADDRESS SPACE 

The Supers can access 64K bytes of program memory and 
64K bytes of data memory. These spaces can be either 
combined or separate. If separate, they are controlled by the 
DM line (Port P35), which selects data memory when Low 
and program memory when High. 

Figure 9 shows the system memory space. 

CPU Program Memory 

Program memory occupies addresses to 64K. External 
program memory if present, is accessed by configuring 
Ports and 1 as a memory interface. 

The address/data lines are controlled by AS, DS and R/W. 

The first 32 , program memory bytes are reserved for 
interrupt vectors; the lowest address available for user 
programs is 32 (decimal). This value is automatically loaded 
into the program counter after a hardware reset. 

ROMIess 

Port can be configured to provide from to 8 additional 
address lines. Port 1 is always used as an 8-bit multiplexed 
address/data port. 



ROM and Protopack 

Port 1 is configured as multiplexed address/data or^as I/O. 
When Port 1 is configured as address/data, Port lines can 
be used as additional address lines, up to address 15. 
External program memory is mapped above internal 
program memory; that is, external program memory can 
occupy any space beginning at the top of the internal ROM 
space up to the 64K (1 6-bit address) limit. 

CPU Data Memory 

The external CPU data memory space, if separated from 
program memory by the DM optional output, can be 
mapped anywhere from to 64K (full 1 6-bit address space). 
Data memory uses the same address/data bus (Port 1) and 
additional addresses (chosen from Port 0) as program 
memory. Data memory is distinguished from program 
memory by the DM pin (P35), and by the fact that data 
memory can begin at address OOOOh- This feature differs 
from the Z8. 



THIS BOUNDARY 

MAY BE AT 0, OR 

8192 DEPENDING ON 

ROM SIZE 



EXTERNAL 
PROGRAM 
MEMORY 



INTERRUPT VECTORS 



ON-CHIP 
I ROM OR 
f PROTOPACK 

EPROM 



EXTERNAL 

DATA 
MEMORY 



PROGRAM MEMORY 



DATA MEMORY 



Figure 9. Program and Data Memory Address Spaces 
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INSTRUCTION SET 



The Supers instruction set is designed to handle its large 
register set. The instruction set provides a full connplement 
of 8-bit arithmetic and logical operations, including multiply 
and divide. It supports BCD operations using a decimal 
adjustment of binary values, and it supports incrementing 
and decrementing 16-bit quantities for addresses and 
counters. 

It provides extensive bit manipulation, and rotate and shift 
operations, and it requires no special I/O instructions— the 
I/O ports are mapped into the register file. 

Instruction Pointer 

A special register called the Instruction Pointer (IP) provides 
hardware support for threaded-code languages. It consists 
of register-pair R218 and R219, and it contains memory 
addresses. The MSB is R21 8. 

Threaded-code languages deal with an imaginary 
higher-level machine within the existing hardware machine. 
The IP acts like the PC for that machine. The command 
NEXT passes control to or from the hardware machine to the 
imaginary machine, and the commands ENTER and EXIT 
are imaginary machine equivalents of (real machine) CALLS 
and RETURNS. 

If the commands NEXT ENTER, and EXIT are not used, the 
IP can be used by the fast interrupt processing, as 
described in the Interrupts section. 

Flag Register 

The Flag register (FLAGS) contains eight bits that describe 
the current status of the Super8. Four of these can be tested 
and used with conditional jump instructions; two others are 
used for BCD- arithmetic. FLAGS also contains the Bank 
Address bit and the Fast Interrupt Status bit. 

The flag bits can be set and reset by instructions. 



CAUTION 

Do not specify FLAGS as the destination of an 
instruction that normally affects the flag bits or the 
result will be unspecified. 



The following paragraphs describe each flag bit: 

Bank Address. This bit is used to select one of the register 
banks (0 or 1) between (decimal) addresses 224 and 255. It 
is cleared by the SBO instruction and set by the SB1 
instruction. 

Fast Interrupt Status. This bit is set during a fast interrupt 
cycle and reset during the IRET following interrupt servicing. 
When set, this bit inhibits all interrupts and causes the fast 
interrupt return to be executed when the IRET instruction is 
fetched. 

Half-Carry. This bit is set to 1 whenever an addition 
generates a carry out of bit 3 , or when a su btraction borrows 
out of bit 4. Jhis bit is used by the Decimal Adjust (DA) 
instruction to convert the binary result of a previous addition 
or subtraction into the correct decimal (BCD) result. This 
flag, and the Decimal Adjust flag, are not usually accessed 
by users. 

Decimal Adjust. This bit is used to specify what type of 
instruction was executed last during BCD operations, so a 
subsequent Decimal Adjust operation can function 
correctly. This bit is not usually accessible to programmers, 
and cannot be used as a test condition. 

Overflow Flag. This flag is set to 1 when the result of a 
twos-complement operation was greater than 127 or less 
than -1 28. It is also cleared to during logical operations. 

Sign Flag. Following arithmetic, logical, rotate, or shift 
operations, this bit identifies the state of the MSB of the 
result. A indicates a positive number and a 1 indicates a 
negative number 

Zero Flag. For arithmetic and logical operations, this flag is 
set to 1 if the result of the operation is zero. 

For operations that test bits in a register, the zero bit is set to 1 
if the result is zero. 

For rotate and shift operations, this bit is set to 1 if the result is 
zero. 

Carry Flag. This flag is set to 1 if the result from an arithmetic 
operation generates a carry out of, or a borrow into, bit 7. 

After rotate and shift operations, it contains the last value 
shifted' out of the specified register. 

It can be set, cleared, or complemented by instructions. 



446 



Condition Codes Addressing IVIodes 

The flags C, Z, S, and V are used to control the operation of All operands except for immediate data and condition 

conditional jump instructions. codes are expressed as register addresses, program 

The opcode of a conditional jump contains a 4.bit field "1^°^^ addresses, or data memory addresses. The 

called the condition code (cc). This specifies under which addressing modes and their designations are: 
conditions it is to execute the jump. For example, a Register (R) 

conditional jump with the condition code for "equal" after a Indirect Register (IR) 

compare operation only jumps if the two operands are Indexed (X) 

equal. Direct (DA) 



The condition codes and their meanings are given in , ^- ^ /l^/.^ 

Table 4. Immediate (IM) 



Relative (RA) 
Immediate (I 
Indirect (lA) 



Table 4. Condition Codes and Meanings 


Binary 


Mnemonic 


Flags 


Meaning 


0000 


F 


— 


Always false 


1000 


— 


— 


Always true 


0111* 


C 


C=^1 


Carry 


1111* 


NC 


c=o 


No carry 


0110* 


Z 


Z = 1 


Zero 


1110* 


NZ 


z=o 


Not zero 


1101 


PL 


s=o 


Plus 


0101 


Ml 


S = 1 


Minus 


0100 


OV 


V=1 


Overflow 


1100 


NOV 


v=o 


No overflow 


0110* 


EQ 


Z=1 


Equal 


1110* 


NE 


z=o 


Not equal 


1001 


GE 


(SXORV) = 


Greater than or equal 


0001 


LT 


(SX0RV) = 1 


Less than 


1010 


GT 


(ZOR(SXORV)) = 


Greater than 


ooto 


LE 


(Z0R(SX0RV)) = 1 


Less than or equal 


1111* 


UGE 


C = 


Unsigned greater than or equal 


0111* 


ULT 


C = 1 


Unsigned less than 


1011 


UGT 


(C = 0ANDZ = 0) = 1 


Unsigned greater than 


0011 


ULE 


(C0RZ) = 1 


Unsigned less than or equal 



NOTE: Asterisks (*) indicate condition codes that relate to two different mnemonics but test the same flags, f^or example, Z and EQ are both True if the 
Zero flag is set, but after an ADD instruction, Z would probably be used, while after a CP instruction, EQ would probably be used. 
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Registers can be addressed by an 8-bit address in tlie range 
of to 255. Working registers can also be addressed using 
4-bit addresses, where five bits contained in a register 
pointer (R218 or R219) are concatenated with three bits 
from the 4-bit address to fornn an 8-bit address. 

Registers can be used in pairs to generate 1 6-bit program or 
data memory addresses. 



Notation and Encoding 

The instruction set notations are described in Table 5. 

Functional Summary of Commands 

Figure 10 shows the formats followed by a quick reference 
guide to the commands. 



Table 5. Instruction Set Notations 



Notation Meaning 



Notation Meaning 



CO Condition code (see Table 4) 

r Working register (between and 1 5) 

rb Bit of working register 

rO Bit of working register 

R Register or working register 

RR Register pair or working register pair (Register pairs 

a' ways start on an even-number boundary) 

lA Indirect address 

Ir Indirect working register 

IR Indirect register or indirect working register 

Irr Indirect working register pair 

IRR Indirect register pair or indirect working register pair 

X Indexed 

XS Indexed, short offset 

XL Indexed, long offset 



DA 


Direct address (between and 65535) 


RA 


Relative address 


IM 


Immediate 


IML 


Immediate long 


dst 


Destination operand 


src 


Source operand 


@ 


Indirect address prefix 


SP 


Stack pointer 


PC 


Program counter 


IP 


Instruction pointer 


FLAGS 


Flags register 


RP 


Register pointer 


# 


Immediate operand prefix 


o/o 


Hexadecimal number prefix 


OPC 


Opcode 



dst I OPC 



I OPC 



I OPC 



dst 1 OPc' 



I OPC 



One-Byte Instructions 



CCF, Dl, El, ENTER, EXIT. IRET NEXT, NOP, 
RCF, RET, SBO; SB1 , SCF, WFI 



IWo-Byte Instructions 



I LDE, LDED, OR, SBC, SUB, TCM, TM, XOR 



src I dst i LDC, LDCPD, LDCPI, LDE, LDEPD, LDEPI 



I CALL, DA, DEC, DECW, INC, INCW, JP, POP 
I RL, RLC, RR, RRC, SWAP, CLR, SRA, COM 



src I PUSH, SRP, SRPO, SRP1 



dst I b |0l BITC, BITR 



dst I b hi BITS 
dst I DJNZ 



Figure 1 0. Instruction Formats 
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Three-Byte Instructions 



cc I OPC 



1 dst 1 




1 src 1 




1 dst 1 b |0i 




1 src 1 b |1| 




i src 1 b |0| 




1 src 1 dst 1 




1 dst 1 X 1 




1 src 1 X 1 



-1 ADC,ADD,AND, CP, LD.OR, PUSHUD, 

J PUSHUI, SBC, SUB, TCM, TM, XOR 

-I ADC, ADD, AND, CP, DIV, LD, LDW, MULT, 

-I OR, POPUD, POPUI, SBC, SUB, TCM, TM, XOR 



src I BAND, BCP, BOR, BXOR, LDB 



dst 



dst i BAND, BOR, BTJRT, BXOR, LDB 

BTJRF 

CPIJE, CPIJNE 
LD, LDC, LDE 



dst I LD, LDC, LDE 

I CALL 



Four-Byte Instructions 



r^st 


1x^0 orl| 




1 ^'^^ 


|x^Oorl| 




1 dst 


1 0000 1 




1 src 


1 0000 1 




1 dst 


1 0001 1 




1 dst 


1 0001 1 




1 •"' 1 



src I LDC, LDE 



FOR LDC, X = EVEN 
FOR LDE, X = ODD 



]] LDC- 
"2 LDC 
]] LDE 
~1 LDE 



J LDW 



Figure 10. Instruction Formats (Continued) 



INSTRUCTION SUMMARY 



Instruction 
and Operation 


AddrMode 


Opcode 
Byte 
(Hex) 


Flags Affected 


dst 


src 


C Z 


S V D H 


ADC dst.src 

dst *- dst + src + C 


(Note1) 


'in 


* * 


* - * 


ADD dstsrc 
dst *- dst + src 


(Note1) 


on 


* * 


it * * 


AND dst.src 

dst*- dst AND src ' 


(Note1) 


5n 


— * 


* 


BAND dst.src 
dst ^ dst AND src 


rO 
Rb 


Rb 
rO 


67 
67 


— * 


u 


BCP dst, src 
dst - src 


rO 


Rb 


17 


— * 


u 


BITC dst 

dst ^ NOT dst 


rb 




57 


— * 


u • 


BITR dst 

dst^O 


rb 




77 










BITS dst 

dst-1 


rb 




77 











AddrMode 


Opcode 
Byte 
(Hex) 


Flags Affected 


and Operation dst 


src 


C Z S V D H 


BOR dst, src rO 
dst ^ dst OR src Rb 


rB 
rO 


07 


- * U 


BTJRF RA 

if src = 0, PC = PC + dst 


rb 


37 




BTJRT RA 

ifsrc = 'l,PC = PC + dst 


rb 


37 




BXOR dst, src rO 
dst ^ dst XOR src Rb 


Rb 
rO 


27 
27 


- * u 



CALL dst 


DA 


F6 


SP^SP-2 


IRR 


F4 


@SP ^ PC 


lA 


D4 


PC *- dst 







CCF 

C = NOTC 




EF 


* 


CLRdst 

dst*-0 


R 
IR 


BO 
B1 
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INSTRUCTION SUMMARY (Continued) 



Instruction 
and Operation 


AddrlMode 


Opcode 
Byte 
(Hex) 


Flags Affected 


dst src 


C Z S V D H 


COM dst 

dst ^ NOT dst 


R 
^ IR 


60 
61 


- * * 


GP dst.src 
dst - src 


(Note1) 


AD 


* * * * 



CPIJE 

if dst - src = O.then 
PC^PC + RA 
lr*-lr + 1 



C2 



CPIJNE r 

if dst - src = 0,then 
PC ^ PC + RA 
Ir^lr + 1 



02 



DA dst 

dst *- DA dst 


R 


40 
41 


* * * U 


DEC dst 
dst ^ dst- 1 


R 
IR 


00 
01 


— * * * 


DECW dst 

dst *- dst - 1 


RR 
IR 


80 
81 


— * * * 


Dl 

SMR(0)-0 




8F 





DIV dst, src 
dst -^ src 
dst (Upper) *- 

Quotient 
dst (Lower) *- 

Remainder 



DJNZr.dst 

r-^-r - 1 
ifr = 
PC ^ PC + dst 



El 

SMR(0)^1 



RR R 94 

RR IR 95 



* * * * 



RR IM 



96 



RA 



rA 
(r = OtoF) 

9F 



ENTER 

SP-SP-2 




IF 






@SP<-IP 










IP*- PC 










PC-@IP 










IP ^ IP + 2 










EXIT 

IP-@SP 




9F 














SP-SP + 2 










PC-@IP 










IP*-IP + 2 










INC dst 


r 


rE 


- * * * - 





dst *- dst + 1 


R 
IR 


(r = OtoF) 
20 
21 







Instruction 
and Operation 


AddrMode 
dst src 


^•1 


Flags Affected 
C Z S V D H 


INCW dst 

dst *- 1 + dst 


RR 

IR 


AO 

A1 


— * * * , 



IRET (Fast) 
PC** IP 
FLAG*- FLAG' 
FIS*-0 



BF 



Restored to 
-before interrupt 



IRET (Normal) BF Restored to 

FLAGS *- @SP; SP *- SP + 1 before interrupt 

PC ^ @SP; SP *- SP + 2; SMR (0) ^ 1 



JP ccdst 
if cc is true, 
PC*- dst 



DA 



IRR 



JR cc,dst 
.if cc is true, 
PC *- PC + d 



RA 



LD dst, src 
dst *- src 



r 
r 
R 

, r 
IR 
R 
R 
R 
IR 
IR 
r 

X 



IM 
R 

r 



R 
IR 
IM 
IM 
R 

X 

r 



ccD 

(cc='OtoF) 

30 

ccB 
(cc = OtoF) 

' rC 

r8 

r9 

(r = OtoF) 

,C7 

D7 

E4 

E5 

E6 

D6 

F5 

87 

97 



LDB dst, src 
dst *- src 



rO Rb 
Rb rO 



47 
47 



LDC/LDE 

dst *- src 



r 


Irr 


C3 


Irr 


r 


D3 


r 


xs 


E7 


xs 


r 


F7 


r 


xl 


A7 


Xl 


r 


B7 


r 


DA 


A7 


DA 


r 


B7 



LDCD/LDED dst, src r 
dst *- src 
rr **- rr - 1 



E2 



LDEI/LDCI dst, src r 
dst *- src 
rr *- rr + 1 



Irr 



E3 



LDCPD/LDEPD dstsrc 
rr^rr - 1 Irr r 

dst *- src 



F2 
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INSTRUCTION SUMMARY (Continued) 



Addr Mode Opcode Flags Affected 

Byte 

dst src (Hex) C Z S V D H 



Instruction 
and Operation 



Addr Mode Opcode Flags Affected 

Byte — 

dst src (Hex) Z S V D H 



Instruction 
and Operation 



LDCPI/LDEPI dst, src 
rr"*-rr + 1 Irr 

dst *- src 



F3 



LOW dst, src 
dst*- src 



MULT dst, src 



RR 


RR 


C4 


RR 


IR 


C5 


RR 


IMM 


C6 


RR 


R 


84 


RR 


IR 


85 


RR 


IM 


86 



PLC dst 

dst(0)^C 
C^dst(7) 
dst(N + 1)^dst(N) 
N = 0to6 



R 
IR 



10 
11 



* * * 



RRdst 
C*-dst(0) 
dst (7)^ dst (0) 
dst(N)*-dst(N + 1) 
• N = 0to6 



R 
IR 



EO 

El 



NEXT 

PC^@IP 
IP^IP + 2 



NOP 



OR dst.src 

dst *- dst OR src 



(Notel) 



POP dst 

dst *- @SP; 
SP^SP + 1 



R 
IR 



POPUD dst, src 
dst ^ src 
IR^IR- 1 



IR 



POPUI dst, src 
dst -^ src 
IR-IR + 1 



IR 



PUSH src R 

SP^SP- 1;@SP^src IR 



PUSHUD dst. src IR 

IR*-|R- 1 
dst -*- src 



PUSHUI dst, src IR 

IR^IR + 1 
dst -*- src 



RGF 

C*-0 



RET 

PC*-@SP;SP^SP + 2 



OF 

RRC dst R 

C^dst(O) IR 

dst(7)^C 

FF dst(N)^dst(N + 1) 

~7^ n N = 0to6 

4n — * * — 

50 

51 

92 

93 

SRA dst R 

dst (7) *- dst (7) I R 

70 C*-dst(0) 

71 dst(N)^dst(N + 1) 
~^ N = 0to6 

83 

CF 

AF 



CO 
CI 



RLdst 
C^dst(7) 
dst (0)^ dst (7) 
dst(N + 1)-dst(N) 
N = 0to6 



R 
IR 



90 
91 



* * * * 



* * * * 



* * * * 



* * * * 



SBO 

BANK^O 






4F 




SB1 

BANK^I 






5F 




SBC dst, src 
dst ^ dst - src ■ 


-c 


(Notel) 


3a 


* * * * 1 * 


SCF 

C-1 






DF 


1 



DO * * * 

D1 



SRP src 

RPO^IM 
RP1 *-IM + 


8 


IM 


31 




SRPO 

RPO-IM 




M 


31 




SRP1 

RPI^IM 




IM 


31 




SUB dst,src 
dst *-,dst - 


src 


. (Notel) 


2D 


* * * * 1 * 
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INSTRUCTION SUMMARY (Continued) 



instruction 
and Operation 


AddriMode 
dst src 


Opcode 
Byte 
(Hex) 


Flags Affected 
C Z S V D H 


SWAPdst 

dst(0-3)-*dst(4-7) 


R 
IR 


FO 
F1 


- ♦ * U 


TCIWidst.src 
(NOTdst)ANDsrc 


(Note1) 


en 


- * * 


TiVi dst.src 
dstANDsrc 


(Note1) 


70 


- * * 


WFI 




3F 




XOR dst.src 
dst*-dstXORsrc 


(Note1) 


BD 


- * * 



Tabie 6. Second Nibbie 



NOTE 1 : These instructions have an identical set of addressing nnodes, 
which are encoded for brevity. The first opcode nibble identifies 
the command, and is found in the table above. The second 
nibble, represented by a D, defines the addressing mode as 
shown in Table 6.: 



Addrl\Aode 


Lower 


dst 


src 


Opcode Nibbie 


r 


r 


m 


r 


Ir 


m 


R 


R 


m 


R 


IR 


m 


R 


IM 


m 



For example, to use an opcode represented as xD with an "RR" 
addressing mode, use the opcode "x4." 

= Cleared to Zero 

1 = Set to One 
— = Unaffected 

* = Set or reset, depending on result of operation. 
U = Undefined 
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SUPER-8 OPCODE MAP 



Lower Nibble (Hex) 

6 7 8 9 



-ST 6 



0> 

a 
a 



6 


6 


6 


6 


10 


10 


10 


10 


6 


6 


12/10 


12/10 


6 


12/10 


6 


14 


DEC 


DEC 


ADD 


ADD 


ADD 


ADD 


ADD 


BOR* 


LD 


LD 


DJNZ 


JR 


LD 


JP 


INC 


NEXT 


Ri 


iRi 


ri.r2 


'■l.l''2 


R2.R1 


IR2.R1 


Rl.lM 


ro-Rb 


ri-R2 


r2.Rl 


ri,RA 


ccRA 


ri.lM 


cc.DA 


r1 




6 


6 


6 


6 


10 


10 


10 


10 






























20 . 


RLC 


RLC 


ADC 


ADC 


ADC 


ADC 


ADC 


BCP 






























ENTER 


Ri 


IRi 


h.r2 


ri.lr2 


R2.R1 


IR2.R1 


Rl.lM 


ri,b.R2 
































6 


6 


6 


6 


10 


10 


10 


10 


22 


INC 


INC 


SUB 


SUB 


SUB 


SUB 


SUB 


BXOR* 






























EXIT 


Ri 


lRi 


ri,r2 


ri.lr2 


R2.R1 


IR2.R1 


Rl,IM 


ro-Rb 
































10 - 




6 


6 


10 


10 


10 




.6 


jp 


NOTE 
C 


SBC 


SBC 


SBC 


SBC 


SBC 


NOTE 
A 






























WFI 


IRRi 


i'l.r2 


''^M2 


R2.R1 


IR2.R1 


Rl.lM 
































6 


6 


6 


6 


«P 


10 


10 


10 


,6 


DA 


DA 


OR 


OR 


OR 


OR 


OR 


LDB* 






























SBO 


Ri 


IRi 


n.r2 


M.l''2 


R2.R1 


IR2.R1 


Rl,IM 


ro-Rb 
































10 


10 


6 


6 


10 


10 


10 


8 


6 


POP 


POP 


AND 


AND 


AND 


AND 


AND 


BITC 






























SBI 


Ri 


IRi 


ri.r2 


'■i.lr2 


R2.R1 


IR2.R1 


Rl.lM 


ri,b 
































6 


6 


6 


6 


10 


10 


10 


10 




COM 


COM 


TCM 


TCM 


TCM 


TCM 


TCM 


BAND* 
































Ri 


IRi 


ri.r2 


ri.lr2 


R2.R1 


IR2.R1 


Rl,IM 


ro-Rb 
































10/12 


12/14 


6 


6 


10 


10 


10 ' 


NOTE 
B 




PUSH 


PUSH 


TM 


TM 


TM 


TM 


TM 
































R2 


IR2 


ri,r2 


''1.li'2 


R2.R1 


IR2.R1 


Rl,IM 
































10 


10 


10 


10 


24 


24 


24 


10 


6 


DECW 


DECW 


PUSHUD 


PUSHUi 


MULT 


MULT 


MULT 


LD 






























Dl 


RRl 


IRi 


IR1.R2 


IRi,R2 


R2.RR1 


IR2,RRi 


IM.RRi 


ri,x,r2 
































6 


6 


10 


10 


28/12 


28/12 


28/12 


10 


6 


RL 


RL 


POPUD 


POPUI 


DIV 


DIV 


DIV 


LD 






























El 


Ri 


IRi 


IR2.R1 


IR2.R1 


R2,RRi 


IR2,RRi 


IM.RRi 


r2,x,ri 
































10 


10 


6 


6 


10 


10 


10 


NOTE 
D 


14 


INCW 


INCW 


CP 


CP 


CP 


CP 


CP 






























RET 


RRl 


IRi 


ri.r2 


^1.1^2 


R2,Ri 


IR2.R1 


Rl,IM 
































6 


6 


6 


6 


10 


10 


10 


NOTE 

E 


16/6 


CLR 


CLR 


x6r 


XOR 


XOR 


XOR 


XOR 






























IRET 


Rl 


IRi 


ri.''2 


ri.lrg 


R2.R1 


lR2,Ri 


Rl,IM 
































6 


6 


16/18 


12 


10 


10 


12 


6 


6 


RRC 


RRC 


CPIJE 


LDC* 


LDW 


LDW 


LDW 


LD 






























RCF 


Ri 


IR1 


lr,r2,RA 


ri,lrr2 


RR2,RRi 


IR2,RRi 


RRl,IML 


ri.lr2 
































6 


6 


16/18 


12 


20 




10 


/6 


6 


SRA 


SRA 


CPIJNE 


LDC* 


CALL 




LD 


LD 






























SCF 


Ri 


IRi 


lri,r2.RA 


r2,lFri 


IA1 




IRl,IM 


Iri.r2 
































6 


6 


16 


16 


10 


10 


10 


18 


6 


RR 


RR 


LDCD* 


LDCI* 


LD 


LD 


LD 


LDC* 






























CCF 


Ri 


JRi 


ri,lrr2 


ri,lrr2 


R2.R1 


lR2,Ri 


Rl.lM 


r-|,lrr2,xs 
































8 


8 


16 


16 


18 


10 


18 


18 


6 


SWAP 


SWAP 


LDCPD* 


LDCPI* 


CALL 


LD 


CALL 


LDC* 






























NOP 


Rr 


IRi 


r2,lrri 


r2,irri 


IRR1 


R2,IRi 


DAi 


r2,lrri,xs 


^ 


r 


) 


' 


^ 


r 


\ 


r 


\ 


r 


\ 


r 


y 


' 





16/18 
BTJRF 

r2,b,RA 


16/18 
BTJRT 

r2,b,RA 



NOTEB 


8 
BITR 

ri,b 


8 
BITS 

ri,b 








20 
LDC* 

ri,lrr2,xL 


20 
LDC* 

ri,DA2 


NOTEE 



SRP 

IM 



SRPO SRP1 

IM IM 



20 


20 


LDC* 


LDC* 


r2,lrr2,xL 


r2,DAi 



Figure 1 1 . Opcode IMap 



Legend: 

r = 4-bit a 

R = 8-bit address 

b = bit number 

Ri orri = dst address 

R2 or r2 = src address 



'Examples: 

BOR ro-R2 

isB0Rri,b,R2 

orBORr2,b,Ri 
LDCri,lrr2 

isLDCr-|,lrr2 = program 

orLDEri,lrr2 = data 



Sequence: 

Opcode, first, second, third operands 



NOTE. The blank areas are not defined. 
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INSTRUCTIONS 



Table 7. Supers Instructions 



Mnemonic 


Operands 


Instruction 


IVInemonic 


Operands 


Instruction 


Load Instructions 




Program Control Instructions 


CLR 


dst 


Clear 


BTJRT 


dst, src 


Bit test jump relative on True 


LD • 


dst, src 


Load 


BTJRF 


dst, src 


Bit test jump relative on False 


LDB 


dst, src 


Load bit ^ 


CALL 


dst 


Call procedure 


LDC 


dst, src 


Load program memory 


CPIJE 


dst, src 


Compare, increment and jump on 


LDE 


dst, src 


Load data memory 






equal 


LDCD 


dst, src 


Load program memory and 
decrement 


CPIJNE 


dst, src 


Compare, increment and jump on 
non-equal 


LDED 


dst, src 


Load data memory and . 


DJNZ 


r,dst 


Decrement and jump on non-zero 






decrement 


ENTER 




Enter 


LDCI 


dst, src 


Load program memory and 


EXIT 




Exit > 






increment 


IRET 




Return from interrupt 


LDEI 


dst, src 


Load data memory and increment 


JP 


cc, dst 


Jump on condition code 


LDCPD 


dst, src 


Load program memory with 


JP 


dst 


Jump unconditional 






pre-decrement 


JR 


cc, dst 


Jump relative on condition code 


LDEPD 


dst, src 


Load data memory with 


JR 


dst 


Jump relative unconditional 






pre-decrement 


NEXT 




Next 


LDCPI 


dst, src 


Load program memory with 


RET 




Return 




dst, src 


pre-increment 

Load data memory with 


WFI 




Wait for interrupt 


LDEPI 


Bit l\/lanipulation Instructions 






pre-increment 


BAND 


dst, src 


BitAND 


LDW 


dst, src 


Load word 


BCP 


dst, src 


Bit compare 


POP 


dst 


Pop stack 


BITC 


dst 


Bit complement 


POPUD 


dst, src 


Pop user stack (decrement) 


BITR 


dst 


Bit reset 


POPUI 


dst, src 


Pop user stack (increment) 


BITS 


dst 


Bit set 


PUSH 


src 


Push stack 


BOR 


dst, src 


Bit OR ( 


PUSHUD 


dst, src 


Push user stack (decrement) 


BXOR 


dst, src 


Bit exclusive OR 


PUSHUI 


dst, src 


Push user stack (increment) 


TOM 
TM 


dst, src 
dst, src 


Test complement under mask 
Test under mask 




nstructions / 




Arithmetic li 














Rotate and Shift Instructions 


ADC 


dst, src 


Add with carry 


RL 


dst 


Rotate left 


ADD 


dst, src 


Add 


RLC 


dst 


Rotate left through carry 


CP 


dst, src 


Compare 


RR 


dst 


Rotate right 


DA 


dst 


Decimal adjust 


RRC 


dst 


Rotate right through carry 


DEC 


dst 


Decrement 


SRA 


dst 


Shift right arithmetic 


DECW 
DIV 


dst 
dst, src 


Decrement word 
Divide 


SWAP 


dst 


Swap nibbles 








INC 


dst 


Increment 


CPU Control Instructions 




INCW 


dst 


Increment word 


CCF 




Complement carry flag 


MULT 


dst, src 


Multiply 


Dl 




Disable interrupts 


SBC 


dst, src 


Subtract with carry 


El 




Enable interrupts 


SUB 


dst, src 


Subtract 


NOP 
RCF 
SBO 




Do nothing 
Reset carry flag 








Set bank 


Logical Instructions 




SB1 




Set bank 1 


AND 


dst, src 


Logical AND 


SCF 




Set carry flag 


COM 


dst 


Complement 


SRP 


src 


Set register pointers /. 


OR 


dst, src 


Logical OR 


SRPO 


src 


Set register pointer zero 


XOR 


dst, src 


Logical exclusive 


SRP1 


src 


Set register pointer one 
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INTERRUPTS 

The Supers interrupt structure contains 8 levels of interrupt, 
1 6 vectors, and 27 sources. 

Interrupt priority is assigned by level, controlled by the 
Interrupt Priority register (I PR). Each level is masked (or 
enabled) according to the bits in the Interrupt Mask register 
(IMP), and the entire interrupt structure can be disabled by 
clearing a bit in the System Mode register (R222). 

The three major components of the interrupt structure are 
- sources, vectors, and levels. These are shown in Figure 10 
and discussed in the following paragraphs. 

Sources 

A source is anything that generates an interrupt. This can be 
internal or external to the SuperS MCU. Internal sources are 
hardwired to a particular vector and level, while external 
sources can be assigned to various external events. 
External interrupts are falling-edge triggered. 

Vectors 

The 16 vectors are divided unequally among the eight 
levels. For example, vector 1 2 belongs to level 2, while level 
3 contains vectors 0,2,4, and 6. 



The vector number is used to generate the address of a 
particular interrupt servicing routine; therefore all interrupts 
using the same vector must use the same interrupt handling 
routine. 

Levels 

Levels provide the top level of priority assignment. While the 
sources and vectors are hardwired within each level, the 
priorities of the levels can be changed by using the Interrupt 
Priority register (see Figure 8 for bit details). 

If more than one interrupt source is active, the source from 
the highest priority level will be serviced first. If both sources 
are from the same level, the source with the lowest vector will 
have priority. For example, if the UART Receive Data bit and 
UART Parity Error bit are both active, the UART Parity Error 
bit will be serviced first because it is vector 16, and UART 
receive data is vector 20. 

The levels are shown in Figure 1 2. 
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INTERRUPT SOURCES 

COUNTER ZERO COUNT 
EXTERNAL INTERRUPt (PZq) 
EXTERNAL INTERRUPT (P27) 

COUNTER 1 ZERO COUNT 
EXTERNAL INTERRUPT (PSe) 
EXTERNAL INTERRUPT (PS?) 

HANDSHAKE CHANNEL | 
EXTERNAL INTERRUPT (P24) < 
EXTERNAL INTERRUPT (P25) 

HANDSHAKE CHANNEL 1 1 
EXTERNAL INTERRUPT (P34) I 
EXTERNAL INTERRUPT (P35) 



EXTERNAL INTERRUPT (P32) 
EXTERNAL INTERRUPT (P22) 

EXTERNAL INTERRUPT (P23) 
EXTERNAL INTERRUPT (P33) 

UART RECEIVE OVERRUN 
UART FRAMING ERROR 
UART PARITY ERROR 
UART WAKEUP DETECT 
UART BREAK DETECT 
UART CONTROL CHAR DETECT 

UART RECEIVE DATA 
EXTERNAL INTERRUPT (P3o) 

EXTERNAL INTERRUPT (P2o) 

UART ZERO COUNT 
EXTERNAL INTERRUPT (P2i) 
UART TRANSMIT DATA 
EXTERNAL INTERRUPT (P3i) 



POLLING 


VECTORS 


LEVELS 
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Figure 12. Interrupt Levels and Vectors 
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Enables 

Interrupts can be enabled or disabled as follows: 

■ Interrupt enable/disable. The entire interrupt structure 
can be enabled or disabled by setting bit in the System 
Mode register (R222). 

■ Level enable. Each level can be enabled or disabled by 
setting the appropriate bit in the Interrupt Mask register 
(R221). 

■ Level priority The priority of each level can be controlled 
by the values in the Interrupt Priority register (R255, Bank 
0). 

■ Source enable/disable. Each interrupt source can be 
enabled or disabled in the sources' Mode and Control 
register. 

Service Routines 

Before an interrupt request can be granted, a) interrupts 
must be enabled, b) the level must be enabled, c) it must be 
the highest priority interrupting level, d) it must be enabled at 
the interrupting source, and e) it must have the highest 
priority within the level. 

If all this occurs, an interrupt request is granted. 

The Supers then enters an interrupt machine cycle that 
completes the following sequence: 

■ It resets the Interrupt Enable bit to disable all subsequent 
interrupts. 

■ It saves the Program Counter and status flags on the 
stack. 

■ It branches to the address contained within the vector 
location for the interrupt. 

■ It passes control to the interrupt servicing routine. 

When the interrupt servicing routine has serviced the 
interrupt, it should issue an interrupt return (IRET) 
instruction. This restores the Program Counter and status 
flags and sets the Interrupt Enable bit in the System Mode 
register 

Fast Interrupt Processing 

The Supers provides a feature called fast interrupt 
processing, which completes the interrupt servicing in 6 
clock periods instead of the usual 2-2. 



Two hardware registers support fast interrupts. The 
Instruction Pointer (IP) holds the starting address of the 
service routine, and saves the PC value when a fast interru pt 
occurs. A dedicated register, FLAG', saves the contents of 
the FLAGS register when a fast interrupt occurs. 

To use this feature, load the address of the service routine in 
the Instruction Pointer, load the level number into the Fast 
Interrupt Select field, and turn on the Fast Interrupt Enable 
bit in the System Mode register 

When an interrupt occurs in the level selected for fast 
interrupt processing, the following occurs: 

■ The contents of the Instruction Pointer and Program 
Counter are swapped. 

■ The contents of the Flag register are copied into FLAG'. 

■ The Fast Interrupt Status Bit in FLAGS is set. 

■ The interrupt is serviced. 

■ When IRET is issued'after the interrupt service outline is 
completed,. the Instruction Pointer and Program Counter 
are swapped again. 

■ The contents of FLAG' are copied back into the Flag 
register 

■ The Fast Interrupt Status bit in FLAGS is cleared. 

The interrupt servicing routine selected for fast processing 
should be written so that the location after the IRET 
instruction is the entry point the next time the (same) routine 
is used. 

Level or Edge Triggered 

Because internal interrupt requests are levels and interrupt 
requests from the outside are (usually) edges, the hardware 
for external interrupts uses edge-triggered flip-flops to 
convert the edges to levels. 

The level-activated system requires that interrupt-serving 
software perform some action to remove the interrupting 
source. The action involved in serving the interrupt may 
remove the source, or the software may have to actually 
reset the flip-flops by writing to the corresponding Interrupt 
Pending register 
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STACK OPERATION 

The Supers architecture supports stack operations in the 
register file or in data memory. Bit 1 in the external Memory 
Timing register (R254 bank 0) selects between the two. 

Register pair 216-217 forms the Stack Pointer used for all 
stack operations. R21 6 is the MSB and R21 7 is the LSB. 

The Stack Pointer always points to data stored on the top of 
the stack. The address is decremented prior to a PUSH and 
incremented after a POP 

The stack is also used as a return stack for CALLs and 
interrupts. During a CALL, the contents of the PC are saved 
on the stack, to be restored later Interrupts cause the 
contents of the PC and FLAGS to be saved on the stack, for 
recovery by IRET when the interrupt is finished. 

When the SuperS is configured for an internal stack (using 
the register file), R21 7 contains the Stack Pointer R21 6 may 



be used as a general-purpose register, but its contents will 
be changed if an overflow or underflow occurs as the result 
of incrementing or decrementing the stack address during 
normal stack operations. 

User-Defined Stacks 

The Supers provides for user-defined stacks in both the 
register file and program or data memory. These can be 
made to increment or decrement on a push by the choice of 
opcodes. For example, to implement a stack that grows 
from low addresses to high addresses in the register file, use 
PUSHUI and POPUD. For a stack that grows from high 
addresses to low addresses in data memory, use LDEI for 
pop and LDEPD for push. 



COUNTER/TIMERS 



The Supers has two identical independently programmable 
16-bit counter/timers that can be cascaded to produce a 
single 32-bit counter They can be used to count, external 
events, or they can obtain their input internally. The internal 
input is obtained by dividing the crystal frequency by four 

The counter/timers can be set to count up or down, by 
software or external events. They can be set for single or 
continuous cycle counting, and they can be set with a 
bi-value option, where two preset time constants alternate in 
loading the counter each time it reaches zero. This can be 
used to produce an output pulse train with a variable duty 
cycle. 



The counter/tinners can also be programmed to capture the 
count value at an external event or generate an interrupt 
whenever the count reaches zero. They can be turned on 
and off in response to external events by using a gate and/or 
a trigger option. The gate option enables counts only when 
the gate line is Low; the trigger option turns on the counter 
after a transient High. The gate and trigger options used 
together cause the counter/timer to work in gate mode after 
initially being triggered. 

The control and status register bits for the counter/timers are 
shown in Figure 5., 



DMA 



The Supers features an on-chip Direct Memory Access 
(DMA) channel to provide high bandwidth data 
transmission capabilities. The DMA channel can be used by 
the UART receiver, U ART transmitter, or handshake channel 
0. Data can be transferred between the peripheral and 
contiguous locations in either the register file or external 



data memory. A 16-bit count register determines the 
number of transactions to be performed; an interrupt can be 
generated when the count is exhausted. DMA transfers to or 
from the register file require six CPU clock cycles; DMA 
transfers to or from external memory take ten CPU clock 
cycles, excluding wait states. 
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ABSOLUTE MAXIMUM RATINGS 



Voltage on all pins with respect 

to ground -0.3V to +7.0V 

Ambient Operating 

Temperature See Ordering Information 

Storage Temperature -65°Cto +150°C 



Stresses greater than these may cause permanent damage to the device. 
This is a stress rating only; operation of the device under conditions more 
severe than those listed for operating conditions may cause permanent 
damage to the device. Exposure to absolute maximum' ratings for 
extended periods may also cause permanent damage. 



STANDARD TEST CONDITIONS 

Figure 14 shows the setup for standard test conditions. All 
voltages are referenced to ground, and positive current 
flows into the reference pin. 

Standard conditions are: 

■ + 4.75V <Vcc< + 5.25V 

■ GND = OV 

■ 0°C<Ta< +70°C 



FROM OUTPUT 




TEST LOAD (FOR ALL PINS) 



Standard Test Load 



DC CHARACTERISTICS 



Symbol 



Parameter 



Min 



Max 



Unit 



Condition 



VCH 


Clock Input High Voltage 


3.8 


Vcc 


V 


Driven by Extern 


VCL 


Clock Input Low Voltage 


■^0.3 


0.8 


V 


Driven by Extern 


V|H 


Input High Voltage 


2.2 


Vcc 


V 




V|L 


Input Low Voltage 


-0.3 


0.8 


V 




Vrh 


Reset Input High Voltage 


3.8 


Vcc 


V 




Vrl 


Reset Input Low Voltage 


-0.3 ' 


0.8 


V 




VOH 


Output High Voltage 


2.4 




V 


lOH = -400juA 


Vol 


Output Low Voltage 




0.4 


V 


Iql = + 4.0 mA 


l|L 


Input Leakage 


-10 


10 


^A 




lOL 


Output Leakage 


-10 


10 


mA 




l|R 


Reset Input Current 




-50 


mA 




Ice 


Vcc Supply Current 




320 


mA 





458 



INPUT HANDSHAKE TIMING 




■^ 



X 






:^ 



Fully Interlocked Mode 



Strobed Mode 



AC CHARACTERISTICS (20 MHz) 

Input Handshake 



Number $ymbol 



Parameter 



Min 



Max 



Notes** 



1 


TsDI(DAV) 


Data In to Setup Time 





2 


TdDAVIf(RDY) 


DAV^ Input to RDYi Delay 




3 


ThDI(RDY) 


Data In Hold Time from RDY i 





4 


TwDAV 


DAV In Width 


45 


5 


ThDI(DAV) 


Data In Hold Time from DAV i 


130 


6 


TdDAV(RDY) 


DAV t Input to RDY t Delay 




7 


TdRDYf(DAV) 


RDY 1 Output to DAV t Delay 






200 



100 



NOTES: 

1. Standard Test Load 

2. This time assumes user program reads data before DAV Input goes high. RDY will not go high before data is read. 
tTimes given are inns. 

*Times are preliminary and subject to change. 
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OUTPUT HANDSHAKE TIMING 

DATA OUT \ 



© 



RDY IN f 



\ 



-©- 



®- 



®h 



^A-JT 



DAVOUT 




Fully Interlocked Mode 




Strobed Mode 




AC CHARACTERISTICS (12 MHz, 20 MHz) 

Output Handshake 


Number Symbol Parameter 


Min 


Max 


Notes'^ 



1 


TdDO(DAV) 


Data Out to DAV i Delay 


90 


2 


TdRDYr(DAV) 


RDY tInputtoDAVI Delay 





3 


TdDAVOf(RDY) 


DAV \ Output to RDY 1 Delay 





4 


TdRDYf(DAV) 


RDY 1 Input to DAV t Delay 





5 


TdDAVOr(RDY) 


DAV t Output to RDY t Delay 





6 


TwDAVO 


DAV Output Width 


150 



110 



110 



1,2 
1 



NOTES: 

1. Standard Test Load 

2. Time given is for zero value in Deskew Counter. For nonzero value of n where n -- 
tTimes given are in ns. 

*Times are preliminary and subject to change. 



, 2, . . .15 add 2 X n X TpC to the given time. 



AC CHARACTERISTICS (12MHz) 

Read/Write 



Number Symbol 



Parameter 



Normal Timing 
MIn Max 



Extended Timing 
Min Max 



Notest* 



1 


TdA(AS) 


Address Valid to AS t Delay 


35 




115 


2 


TdAS(A) 


AS t to Address Float Delay 


65 




150 


3 


TdAS(DR) 


AS t to Read Data Required Valid 




270 




4 


TwAS 


AS Low Width 


65 




150 


5 


TdA(DS) 


Address Float to DS \ 


20 




20 


6a 


TwDS(Read) 


DS (Read) Low Width 


225 




470 


6b 


TwDS(Write) 


DS (Write) Low Width 


130 




295 


7 


TdDS(DR) 


DS 4 to Read Data Required Valid 




180 




8 


ThDS(DR) 


Read Data to DS t Hold Time 










9 


TdDS(A) 


DS t to Address Active Delay 


50 




135 


10 


TdDS(AS) 


DSttoAS^Delay 


60 




145 


11 


TdDO(DS) 


Write Data Valid to DS (Write) \ Delay 


35 




115 


12 


TdAS(W) 


AS t to Wait Delay 




220 




13 


ThDS(W) 


DSt to Wait Hold Time 










14 


TdRW(AS) 


R/W Valid to AS t Delay 


50 




135 



600 



420 



600 



NOTES: 

1. WAIT states add 167 ns to these times. 

2. Auto-wait states add 167 ns to this time. 

X All times are in ns and are for 12 MHz input frequency 
* Timings are preliminary and subject to change. 
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AC CHARACTERISTICS (20 MHz) 

Read/Write 









Normal Timing 


Extended Timing 




Number 


Symbol 


Parameter 


Min 


Max 


Min 


Max 


Notes** 


1 


TdA(AS) 


Address Valid to AS t Delay 


20 




50 






2 


TdAS(A) 


AS t to Address Float Delay 


35 




85 






3 


TclAS(DR) 


AS t to Read Data Required Valid 




150 




335 


1 


4 


TwAS 


AS Low Width 


35 




85 






5 


TclA(DS) 


Address Float to DS i 














6a 


TwDS(Read) 


DS (Read) Low Width 


125 




275 




1 


6b 


TwDS(Write) 


DS (Write) Low Width 


65 




165 




1 


7 


TdDS(DR) 


DS i to Read Data Required Valid 




80 




225 


1 


/ 8 


ThDS(DR) 


Read Data to DS t Hold Time 














9 


TdDS(A) 


DS t to Address Active Delay 


20 




70 






10 


TdDS(AS) 


DSttoASiDelay 


30 




80 






11 


TdDO(DS) 


Write Data Valid to DS (Write) 1 Delay 


10 




50 






12 


TdAS(W) 


AS t to Wait Delay 




90 




335 


2 


13 


ThDS(W) 


DSt to Wait Hold Time 














14 


TdRW(AS) 


R/W Valid to AS t Delay 


20 




70 







NOTES: 

1. WAIT states add 100 ns to these times. 

2. Auto-wait states add 100 ns to this time. 

t All times are in ns and are for 20 MHz input frequency 
* Timings are preliminary and subject to change. 
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External Memory Read and Write Timing 
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ADDRESS OUT 



IDC 



■<D- 



X 



XjEEX. 



EPROM Read Timing 



AC CHARACTERISTICS (20 MHz) 

EPROM Read Cycle 



Number 


Symbol 


Parameter 


IVIin 


Max 


Notest* 


1 


TdA(DR) 


Address Valid to Read Data Required 
Valid 




170 


1 



NOTES: 

1. WAIT states adcl167 ns to these times. 

tAII times are in ns and are for 12 MHz input frequency. 

*Timings are prel iminary and subject to change. 
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Application Note 



August 19^7 



GETTING STARTED 
WITH THE ZILOG SUPERS 

by Charles M. Link, II 



Any time an engineer switches to a new processor, he 
usually begins the time consuming process of learning 
the quirks of the new part. This article is the first of a 
series of articles written to speed that transition time from 
any other processor to the Zilog Supers. 

Getting started is the most difficult part of switching to a 
strange new processor and development tools. Weeks 
can be spent just getting the first lines of initialization 
code written and successfully assembled. Testing the 
code becomes another problem. The soft ire from this 
article series has been tested and it should be possible 
to copy most of the software directly to a user's applica- 
tion. All of the software is available in machine readable 
form as noted at the end of the article. 

This first article demonstrates the proper initialization of 
the Zilog Su(3er8 microcontroller. It sets up a Z8800 
ROMLESS for 64K bytes of external program memory, 
although most typical applications probably do not re- 
quire more than maybe 4K or 8K bytes. Ports 2 and 3, 
which are bit mappable as inputs or outputs, are set into 
the output mode. Port 4, also bit mappable, is set into 
the input mode. A hardware schematic has been in- 
cluded as an example. 

The hardware schematic shown defines a simple Super8 
implementation that was used to test the code in this 
series of articles. This example defines a simple evalua- 
tion board that contains 32K bytes of programable 
EPROM, and up to 32K bytes of RAM. The design con- 
tains a simple RS-232 interface that is used in future ar- 
ticles of the series. The entire board, including the 
RS-232 interface, is powered from 5 volts. The RAM 
battery option allows the software to be downloaded Into 
the RAM and saved if power fails. Additional logic on the 
design allows a user to protect the lower half of RAM 
with a simple jumper change. This prevents the proces- 
sor from destroying executable code if it goes off into 
space on a power failure. 

Specifically, the ROMLESS Super8 is used as the core. 
The Super8 requires a latch to demultiplex the address 
from the data bus. A 74LS373 fits nicely here, requiring 
only an inverter to correct for the address strobe. The 
'LS373 with Inverter is preferred here rather than a single 
'LS374 because the 'LS373 is a transparent latch and 



will present the address eariier than the 'LS374. JU1 
selects the EPROM size, correcting for the /PGM pin on 
2764 and 27128 EPROMs. It is necessary to use pull 
down resistors on the upper 4 bits of the address bus be- 
cause on reset, the ROMLESS Super8 defines only 12 
bits for address; the other 4 are set as inputs. Since LS- 
TTL devices require more current to pull down the inputs, 
this pull down trick will only work for MOS and CMOS in- 
puts, hence the requirement for the logic chips in this 
design to be HOT type devices. 

The remaining logic is required to select the EPROM or 
RAM. JU2 selects the half-RAM protect mode. JU3 is 
set to determine what size ram to protect. This circuit al- 
lows the lower half of CMOS battery backed RAM to be 
read only, and removes chip select on any writes to that 
address space. Of course, that exact circuitry and the 
battery is optional, and might be replaced by a power 
threshold detector. On the other front, a Maxim MAX 
232 provides the RS-232 interface requiring only 5 volts. 

To make the software initialization more interesting, a 
few other typical initialization tasks are demonstrated. 
The entire block of registers (user ram) is cleared to 
zero, and one of the counter timer units is initialized. to 
provide a periodic interrupt to fomi the heart of a real 
time clock function. 

The program shows the typical pseudo-op usage 
demonstrated. This article series uses a cross as- 
sembler available from Zilog for either an IBM PC or a 
VAX operating under VMS. The program begins by 
defining the registers used as general purpose storage. 
This is done so the user does not have to refer to register 
numbers, but may refer to a nanie equated to the 
register. 

The first 32 bytes of every program (beginning at OOOOH) 
always contain the interrupt vectors for the different sour- 
ces. Using the Zilog assembler, the .WORD pseudo-op 
defines a pair of bytes for each of the 16 sources. 
Program execution begins at location 0020H. Since 
copyright requirements usually require the notice as 
close to the beginning as possible, it becomes necessary 
to jump around an ASCII string. The .ASCII pseudo-op 
generates the necessary string for this notice. 
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The source code describes almost completely, without 
further expiaination, the entire initialization. Once initial- 
ized, the processor loops in a WAIT loop waiting on the 
periodic interrupt generated by the counter/timer. The 
counter timer interrupts 60 times per second, and the in- 
terrupt bumps ram storage locations representing 
seconds, minutes, and hours. Each time a location is 
bumped, an external port line is toggled so that those 
without emulators can see some activity with an oscillo- 
scope. 

One point of notice, is the interrupt service routine for the 
timer. One must reset the end of count interrupt bit (the 
source of inten-upt) before exiting the interrupt service 
routine. 



In the next article of this series, we will take the same 
basic initialization routine and modify it to support the 
serial UART. That article will demonstrate polled serial 
communications using the Zilog Super 8. 

[Editors note: The sofware for this series is available on 
an IBM PC diskette and is included with the Super 8 
Emulator package available from Creative Technology 
Corporation, 5144 Peachtree Road, Suite 301, Atlanta, 
GA 30341. (404) 455-8255. Any Zilog Field Application 
engineer should also be able to provide copies of the 
software on a user provided diskette.] 



.TITLE Sample Zilog Super 8 Initialization 



TITLE: 

DATE: 

PURPOSE: 



PROGRAMMER: 



INIT.S8 

JUNE 17, 1986 

TO DEMONSTRATE INITIALIZATION 

OP THE ZILOG SUPER 8 USING THE 

ZILOG ASMS8 ASSEMBLER 

CHARLES M. LINK, II 



.PAGE 55 ;set maximum page size to 55 lines 

? 

;* * 

;* REGISTER EQUATE TABLE * 

• * * 



period: 


.equ 





; period timer 


second: 


.equ 


1 


; seconds timer 


minute: 


.equ 


2 


; minutes timer 


hours: 


.equ 


3 


; hours timer 



J itltltitltltlcitlclclticltltifltlcif*******************^******* ******* ******* 
;*' ■ - * 

;* INTERRUPT VECTOR TABLE * 

;* * 

************************************************************ 

;this area should always be defined 
;as it reserves the lower 32 bytes 
;for the interrupt table, the name 
;o£ the subroutine for each particular 
/interrupt service would normally be 
; named here. 



INTRO: 


.WORD 


INTRET 


INTRl: 


.WORD 


INTRET 


INTR2 : 


.WORD 


INTRET 


INTR3: 


.WORD 


INTRET 


INTR4 : 


.WORD 


INTRET 


INTR5 : 


.WORD 


INTRET 


INTR6 : 


.WORD 


TIMERO 


INTR7: 


.WORD 


INTRET 


INTR8 : 


.WORD 


INTRET 


INTR9 : 


.WORD 


INTRET 


INTRIO: 


.WORD 


INTRET 


INTRl l: 


.WORD 


INTRET 


INTR12: 


.WORD 


INTRET 


INTR13: 


.WORD 


INTRET 


INTR14 : 


.WORD 


INTRET 


INTR15: 


.WORD 


INTRET 



J*********************************************************** 

;* * 

;* START OF PROGRAM EXECUTION * 

;* ' ^ ' * 

************************************************************ 
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START: jr STARTl ;program execution unconditionally 

; begins at this location after reset 
;and power up. 
•ASCII 'REL 6/16/86 • ;jump around optional ascii string 

;containing release info, copyright, etc. 
STARTl: di ;begin 

; select register bank 
EMT,#OOOOOOOOB ;external memory timing=no wait input, normal 
;memory timing, no wait states, stack internal, 
;and DMA internal 
PO,#OOH ;address begins at OOOOh, set upper byte 
P0M,#11111111B ; select all lines as address 
PM, #001100006 ;enable port as upper 8 bits address 
HlC, #000000008 ;handshake not enabled port 



di 

sbO 

Id 



Id 
Id 
Id 
Id 



port 1 is defined in romless part as address/data, 
here to initialize that port 



it is not necessary 



Id 
Id 
Id 
Id 
Id 
Id 



P2,#00H 
P3,#00H 
P2AM,#10101010B 
P2BM, #101010103 



;port 2 outputs low 
;port 3 outputs low 
;p30,31,20,21 as output 
;p32,33,22,23 as output 
P2CM,#10101010B ;p34,35,24,25 as output 
P2DM, #101010108 ;p36,37,26,27 as output 



Id P4, #000000008 
Id P4D, #111111118 
Id P40D, #000000008 



r clear port 4 register 

rset all bits of P4 as inputs 

ractive push/pull [not necessary since all 

r bits are inputs 



basic Super 8 I/O is initialized, now internal registers 

Id RPO,#OCOH ;set working register low to lower 8 bytes 
Id RP1,#0C8H ;set working register high to upper 8 bytes 
Id SPL,#OFFH ;set stack pointer to start at top of set two 
;note here that only lower 8 bits are used 
;for stack pointer, location OFFH is wasted 
;as stack operation. SPH is general purpose 
; storage . 

now clear the internal memory and stack area 

; point to top of general purpose register 
ZERO: clr esPH ;zero it 

;do it until register set is all cleared 
rzero last register 

now everything except working registers is cleared 

cpu and memory now initialized, set up timer for real time clock 



Id 


SPH,#OFFH 


clr 


eSPH 


dec 


SPH 


1r 


nz,ZERO 


clr 


§SPH 



Id 
Id 

Id 
sbl 
Id 
Id 



Id 



SbO 
Id 



SYM, #000000008 ;disable fast interrupt response 
IPR, #000000108 ; interrupt priority 

;IRQ2>IRQ3>IRQ4>IRQ5>IRQ6>IRQ7>IRQ0>IRQ1 
IMR, #000001008 ;enable only interrupt 2 

; select bank 1 
C0TCH,#^H8(50000) ;high byte of time constant 
C0TCL,#^L8(50000) ;low byte of time constant 

; 12, 000, 000 hertz / 4 / 50,000 = 60 hertz 

;12 Mhz is xtal freq, 4 is internal divider 
COM, #000001008 ;p27,37 is I/O, programmed up/down, no capture 

; timer mode is selected 

; select bank 
COCT, #101001018 ;continuous, count down, load counter, 

;zero count interrupt enable, enable counter 



timer is initialized, now lets enable interrupts and wait 



ei 
WAIT: nop 
nop 
nop 
nop 
jr 



WAIT 



; enable interrupts 



;loop back 
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i nop 




nop 




nop 




TIMERO: inc 


period 


cp 


period, #60 


jr 


ne, NOROLL 


xor 


P2, #000000018 


clr 


period 


inc 


second 


cp 


second, #60 


jr 


ne, NOROLL 


xor 


P2, #000000108 


clr 


second 


inc 


minute 


cp 


minute, #60 


jr 


ne, NOROLL 


xor 


P2, #000001008 


clr 


minute 


inc 


hours 


cp 


hours, #24 


jr 


ne, NOROLL 


clr 


hours 


NOROLL: or 


COCT, #000000108 


nop 




nop 




INTRET: iret 





;bump periodic counter (60 hertz) 

;one second yet? 

;no rollover 

; complement the second bit 

; start it over again 

;bump the seconds timer 

; reached maximum 

;no rollover 

/complement the minute bit 

; start it over again 

;bump the minutes timer 

; reached maximum . 

;no rollover 

/complement the hour bit 

; start it over again 

;bump the hours timer 

; reached maximum 

;no rollover 

; start it over again 

; reset end of count interrupt 



;and return from interrupt 



.END 
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Application Note 



August 1987 



POLLED ASYNCHRONOUS 
SERIAL OPERATION 
WITH THE ZILOG SUPERS 

by Charles M. Link, II 



The transition from one processor to another often invol- 
ves many hours of trlal-and-error software development 
to determine the quirks (manufacturers call it features) of 
the part. Once the real features are discovered, 
programming the processor to perform as described can 
be hazardous to one's health. This article, the second In 
a series of eight, attempts to introduce the Zilog Supers 
user to the serial communications port, and its initializa- 
tion in a polled serial environment. 

The universal asynchronous receiver/transmitter (UART) 
on the Supers is a fairly unique implementation among 
single chip microcomputers in that it supports all of the 
functions generally available only on chip level UARTs. 
The UART is a close approximation of the ZSO^ DART 
device in one channel. It supports independent 
receiver/transmitter clocking, 5 to S bits per character, 
plus optional odd or even parity, and even an optional 
wake-up bit. The UART can serve full duplex com- 
munications via polled, interrupt, or DMA modes of 
operation. Auto-echo and intemal loopback can be 
programmed as options. The most unique of the UART 
features is the character match and interrupt option. 

The following article describes the initialization and use 
of the UART in a polled environment. This software has 
been tested and provides several routines that may be 
copied into a user's software. Although the demonstra- 
tion software does not do much, it is fully functional as a 
stand-alone program, and may be "burned" into eprom 
as a test. 

The basic software is almost the same general purpose 
initialization software from the first article in the series. 
Routines set-up counter/timer for a real time clock op- 
tion. Note, however, the change to configuration register 
P2AM. It is necessary to configure port 30 as input for 
receive data and p31 as output for transmit data. 

The UART initialization sequence begins by setting the 
functions In the UART MODE A register. Since the UMA 
register is in the alternate bank, the instruction SB1 must 
be executed to gain access to the following registers. 
The loaded data selects a XI 6 clock, S bits per charac- 
ter, no parity, and no wake up values. Note that the 
clock options are XI, XI 6, X32, and X64. For true 
asynchronous operation, a clock multiplier option of at 
least XI 6 is required. The X1 mode could be used for 
externally syncing the received data to the UART. The 
transmitter is not affected. 



Next, the baud rate generator must be loaded. The for- 
mula for determining the baud rate is shown below: 



TIME CONSTANT = 
DESIRED RATE) - 1 



(XTAL FREQ / 8 / CLOCK MULT / 



where TIME CONSTANT is a 16 bit value, XTAL FREQ 
is the crystal [frequency in hertz, CLOCK MULT is the 
clock rate loaded into UART MODE A register (as above 
XI, XI 6, X32, and X64), and DESIRED rate is the 
desired bit rate in bits per second. Note that the baud 
rate generator may be used as an additional counter, 
and may be loaded with any value permitting just about 
any crystal frequency to operate the Supers. 

The cross-assembler permitted a single 16-bit decimal 
number to be joaded into the UART BAUD RATE GEN- 
ERATOR, high and low byte, without unnecessary figur- 
ing using the high/low byte pseudo-op. 

The initialization sequence continues, with the UART 
MODE B register next. This example sends port 21 data 
to the port 21 pin. An option allows different clocks to be 
sent out from this pin. It could be used for clocking exter- 
nal logic, or for diagnostic purposes to make sure the 
baud rate generator is running. Auto-echo is not 
selected in this application, as that is primarily what the 
example software does. The receive and transmit clock 
input is the baud rate generator and the generator source 
is the intemal clock; the crystal divided by four. Since 
the baud rate generator has been loaded, it is enabled, 
and the UART is set for nofmal operation (without loop- 
back). Loopback operation permits transmitting and 
receiving data without any external logic in front of the 
SuperS- 

The UART TRANSMIT CONTROL register is initialized 
next in the sequence. Select transmit data out on port 31 
and transmit enable. The stop bits are optional, and the 
DMA and WAKE-UP enables are for features discussed 
In future application articles. At this point, the transmitter 
is operational, and except for housekeeping, is usable. 
The housekeeping is in reference to selecting the bank 
by ex(9cuting the SBO instruction. 

Since polled mode communications are desired, all of the 
UART interrupts are disabled by loading the UART IN- 
TERRUPT ENABLE with all zeros. Lastly, the receiver 
must be enabled by setting bit of the UART RECEIVE 
CONTROL register. 
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This program primarily sends a message to the console 
and then accepts Input from the console and echos it 
upon receiving a carriage return. It is necessary to delay 
sending data to the console after initialization because 
the transmit data line is In the SPACE state when idle. 
Alternately, add a pull-up resistpr to the output, and while 
idle and before initialized, it would exibit the MARK state. 

The transmit character routine "SENDC monitors the 
TRANSMIT BUFFER EMPTY bit of the UART TRANS- 
MIT CONTROL register. When this bit is a "1 ", the trans- 
mit buffer Is empty and may be loaded with a new 
character for transmission. To transmit a character, load 
the character into the UART data register (UIO). 



The receive character routine "GETC monitors the 
RECEIVE CHARACTER AVAILABLE bit of the UART 
RECEIVE CONTROL register. When this bit is a T, a 
new character has been received by the UART. 

The polled mode of UART oppration is simple. Making 
the UART operate in an Interrupt mode requires a few 
minor modifications, and DMA mode requires a few more 
modifications. Those modes are the subject of future ap- 
plication articles In this series. 



.TITLE Sample Zilog Super 8 Serial Port Initialization 



TITLE: 

DATE: 

PURPOSE: 



ASSEMBLER: 
PROGRAMMER: 



UARTl . S 

JULY 17, 1986 

TO DEMONSTRATE INITIALIZATION 

AND USAGE OF SERIAL PORT IN 

POLLED MODE. 

ZILOG ASMS 8 ASSEMBLER 

CHARLES M. LINK, II 



.PAGE 55 ;set maximum page size to 55 lines 
********************************************************* 

* * 

* GENERAL EQUATES * 

* • ^ * 
*********************************************************** 



OR: 
LF: 



.equ 
.equ 



OdH 
OaH 



; carriage return 
;line feed 



************************************************************ 
;* * 

;* REGISTER EQUATE TABLE * 

;* * 

;*********************************************************** 

period: .equ ; period timer 

second: .equ 1 ;seponds timer 

minute: .equ 2 ; minutes timer 

hours: .equ 3 ; hours timer 

; working register equates 

MPTR: .equ RR8 ;message pointer for external memory 

? 

;*********************************************************** 
;* * 

;* INTERRUPT VECTOR TABLE * 

;* * 

;**********************************************•************ 

;this area should always be defined 
;as it reserves the lower 32 bytes 
;for the interrupt table, the name 
;of the subroutine for each particular 
; interrupt service would normally be 
; named here. 



INTRO : 


.WORD 


INTRET 


INTRl : 


.WORD 


INTRET 


INTR2 : 


.WORD 


INTRET 


INTR3 : 


.WORD 


INTRET 


INTR4 : 


.WORD 


INTRET 


INTR5 : 


.WORD 


INTRET 


INTR6 : 


.WORD 


TIMERO 


INTR7 : 


.WORD 


INTRET 


INTR8: 


.WORD 


INTRET 


INTR9 : 


.WORD 


INTRET 


INTRl 0: 


.WORD 


INTRET 


INTRl 1: 


.WORD 


INTRET 


INTRl 2 : 


.WORD 


INTRET 
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INTR13: .WORD INTRET 
INTR14: .WORD INTRET 
INTR15: .WORD INTRET 

J ***it****ie**it1t **************************************** ****** 
;* * 

;* START OF PROGRAM EXECUTION * 

;* * 

J*********************************************************** 

i 

START: jr STARTl ; program execution unconditionally 

; begins at this location after reset 

;and power up. 
.ASCII 'REL 7/17/86* ;juinp around optional ascii string 

; containing release info, copyright, etc. 
STARTl: di ; begin 

sbO ; select register bank 

Id EMT, #000000008 /external memory timing=no wait input, normal 

; memory timing, no wait states, stack internal, 

;and DMA internal 
Id PO,#OOH ;address begins at OOOOh, set upper byte 
Id POM, #111111118 ;select all lines as address 
Id PM, #001100008 ;enable port sts upper 8 bits address 
Id HlC, #000000008 ;handshake not enabled port 

port 1 is defined in romless part as address/data, it is not necessary 
here to initialize that port 

Id P2,#00H ;port 2 outputs low 

Id P3,#00H ;port 3 outputs low 

Id P2AM, #100010108 ;p31,20,21 as output, p30 input 

;it is necessary here to configure p30 as input 
;for the receive data, and p31 as output for 
; transmit data for UART 

Id P28M, #101010108 ;p32, 33, 22,23 as output 

Id P2CM, #101010108 ;p34,35,24,25 as output 

Id P2DM, #101010108 ;p36, 37, 26,27 as output 

Id P4, #000000008 ;clear port 4 register 
Id P4D, #111111118 ;set all bits of P4 as inputs 
Id P40D, #000000008 ;active push/pull [not necessary since all 
; bits are inputs 

basic Super 8 I/O is initialized, now internal registers 

Id RP0,#0C0H ;set working register low to lower 8 bytes 
Id RP1,#0C8H ;set working register high to upper 8 bytes 
Id SPL,#OFFH ;set stack pointer to start at top of set two 
;note here that only lower 8 bits are used 
;for stack pointer, location OFFH is wasted 
;as stack operation. SPH is general purpose 
; storage . 

now clear the internal memory and stack area 

; point to top of general purpose register 
ZERO: clr @SPH ;zero it 

;do it until register set is all cleared 
;zero last register 

now everything except working registers is cleared 

cpu and memory now initialized, set up timer for real time clock 

Id SYM, #000000008 ;disable fast interrupt response 
Id IPR, #000000108 ; interrupt priority 

;IRQ2>IRQ3>IRQ4>IRQ5>IRQ6>IRQ7>IRQ0>IRQ1 
Id IMR, #000001008 ;enable only interrupt 2 
sbl ; select bank 1 

Id C0TCH,#^H8(50000) ;high byte of time constant 
Id C0TCL,#^L8(50000) ;low byte of time constant 

; 12, 000,000 hertz / 4 / 50,000 = 60 hertz 

;12 Mhz is xtal freq, 4 is internal divider 
Id COM, #000001008 ;p27,37 is I/O, programmed up/down, no capture 

; timer mode is selected 



Id 


SPH, # OF] 


clr 


@SPH 


dec 


SPH 


jr 


nz , ZERO 


clr 


eSPH 
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sbO ; select bank 

Id COCT, #10100101B ycontinuous, count down, load counter, 

;zero count interrupt enable, enable counter 

timer is set, now lets initialize the UART for polled operation 



sbl 
Id 



Id 
Id 
Id 



SbO 
Id 



Id 
Id 



UMA, #011100006 



UBGH,#^HB(00009) 
UBGL,#^LB(00009) 
UMB, #000111108 



UTC,#10001000B 

UIE,#OOOOOOOOB 
URC,#00000010B 



;bank 1 

;time constant = (12,000, 000/4/16/9600/2) -1= 
;8.76 rounded to 9. 

;note that a 12 Mhz does not make a very 
; accurate baud rate source, error is large 

;high byte of time constant 

;low byte of time constant 
;p21=p21data, auto-echo is off, transmit and 
; receive clock is baud rate generator output, 
;baud rate generator input is system clock / 2, 
;baud rate generator is enabled, loopback 
;is disabled 
; select bank 

; select p31 as transmit data out, 1 stop bit 
;and transmit enable 
; disable all interrupts, no DMA 
; enable receive 



UART is initialized, enable interrupts for real time clock 

ei ; enable interrupts 

wait 1 full second for serial line to mark before sending anything 



WAIT: 



cp 
jr 



second, #1 
ne,WAIT 



display the logon message 
LOGON: 



Idw 
call 



MPTR,#MSG 
SENDM 



;wait 1 second 



;load the address of MSG into word reg MPTR 
;sehd the message 



logon message displayed, get response from console 
and move to upper register memory 



GET: 


Id 


rl,#80 




Id 


r2,#80H- 


GETN: 


call 


GETC 




and 


r0,#7fH 




call 


SENDC 




Id 


er2,r0 




cp 


rO,#CR 




jr 


eq,ECHO 




inc 


r2 




djnz 


rl,GETN 


;if carriage 
• 


return typed. 


ECHO: 


Idw 


MPTR, #MSG1 




call 


SENDM 




Id 


rl,#80 




Id 


r2,#80H 


ECHOl: 


Id 


r0,@r2 




call 


SENDC 




cp 


rO,#CR 




jr 


eq, LOGON 




inc 


r2 




djnz 


rl , ECHOl 




jr 


LOGON 


/subroutines 




; send 


message 


at MPTR until 


SENDM: 


Idci 


rO,@MPTR 




call 


SENDC 




cp 


rO,#'$' 




jr 


ne, SENDM 




ret 





; maximum character count 

; point to first location in upper register bank 

;get input from console 

; remove upper parity bit 

;echo to console 

;move to upper internal ram in Super8 

;was the received character a carriage return 

;if so, echo it to console 

;bump pointer 

;get next character if not done 



;load the address of MSGl in word reg MPTR 

;send the message 

/maximum character count 

; first location of character buffer 

;get character from buffer 

;send the character to console 

/carriage return? 

;if so, end message display 

;bump pointer 

/display next character if not done 



character found 

/get the character 

/otherwise send character 

/last character? 

/and loop back to send next one 
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;send character in rO 

SENDC: tm UTC, #000000108, 

jr z, SENDC 

Id UIO,rO 

ret 
;get a character from the uart, 
GETC: tm URC, #00000001B 

j r Z, GETC 

Id rO,UIO 

ret 



; transmit buffer empty yet 

;if not, wait until it is 

;load the character into the transmitter 

return in rO 

/character available 

;if not, wait until it is 

;get the character from the receiver 



real time interrupt running in background 



TIMERO: inc 
cp 
jr 
xor 
clr 
inc 
cp 
jr 
xor 
clr 
inc 
cp 
jr 
xor 
clr 
inc 
cp 
jr 
clr 

NOROLL: or 
nop 
nop 

INTRET: iret 



period 

period, #60 

ne, NOROLL 

P2, #000000016 

period 

second 

second, #60 

ne, NOROLL 

P2,#00000010B 

second 

minute 

minute, #60 

ne, NOROLL 

P2,#00000100B 

minute 

hours 

hours, #24 

ne, NOROLL 

hours 

COCT, #000000103 



;bump periodic counter (60 hertz) 

;one second yet? 

;no rollover 

; complement the second bit 

; start it over again 

;bump the seconds timer 

; reached maximum 

;no rollover 

; complement the minute bit 

; start it over again 

;bump the minutes timer 

preached maximum 

;no rollover 

/complement the hour bit 

; start it over again 

;bump the hours timer 

/reached maximum 

;no rollover 

/start it over again 

/reset end of count 



/and return from interrupt 



MSG: .ASCII CR,LF, 'Supers Uart test program. • ,CR,LF 

.ASCII 'Enter up to one full line followed by return' ,CR,LF, •$' 
MSGl: .ASCII CR,LF, 'Echoed back, your line was. . . ' ,CR,LF, '$• 



.END 
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USING THE ZILOG SUPERS 
IN INTERRUPT DRIVEN 
COMMUNICATIONS 

by Charles M. Link, II 



The power of the Supers microcomputer lies in its on 
board peripherals. One of those peripherals is the full 
duplex DART. The UART can operate under program 
control In polled mode, or under interrupt control, and in 
a DMA mode. This article, the third in a series, discus- 
ses using the UART in a fully interrupt driven system. 
Since it is assumed that the reader has access to the 
earlier article discussing the UART and the polled mode 
of operation, this article will only discuss the differences. 

The Zilog Supers contains an on board interrupt control- 
ler that is tightly linked to the other on-board peripherals. 
The UART, being on-board, can be operated in an inter- 
rupt mode permitting very little execution overhead time 
while monitoring the UART for Incomming characters and 
waiting for the UART to send outgoing characters. 

Operation of an interrupt driven system demands more 
software logic to control the interrupt. Although more 
software is present, less time is spent executing it, be- 
cause most of the overhead is in the setup for interrupt 
transfers. Generally, interrupt driven serial I/O overlaps 
some other process or processes, and therefore enhan- 
ces total system speed and operation. Interrupt driven 
I/O has no advantages in a system that must wait on the 
serial port. In the example program, no real advantage 
has been gained by interrupt operation. The program 
displays a simple message to the console, and accepts 
input responses and echos them. For program 
simplicity, the main program waits on the interrupt to 
complete before starting the next phase of the program. 

In any interrupt driven system, the central processor 
must know what to do when an interrupt occurs. The 
Supers is no exeception. An interrupt vector table 
directs the processor to begin execution at certain ad- 
dresses for particular interrupt inputs. The UART can be 
the source for up to five different interrupts and therefore 
up to five of the sixteen vectors can be designated for it. 
This sample program ignores en-ors and special condi- 
tion interrupts, and therefore only two vectors are used; 
one for transmit buffer empty and one for receive charac- 
ter available. These vectors are programmed into the 
vector table by setting interrupt vector 10 (zero 
reference) to the address for the receive data service 
routine, and setting interrupt vector 13 to the address for 
the transmit data service routine. 



The setup of the Supers is essentially the same as that 
of the serial port in a polled mode of operation. The 

proper priority for the inten-upts are assigned arbitrarily. 
The real time clock as highest priority, the receive 
character available as second priority, and transmit 
character buffer empty as the lowest priority. Generally, 
the transmit interrupt should be the lowest in an 
asynchronous system because if it does not get serviced 
limmediately, no major problems occur. If the real time 
interrupt took more time in relationship to the time re- 
quired to transmit a single character, then maybe the 
receive should be put higher. If the receiver is not ser- 
viced, that character would be lost. 

Enabling the interrupts is a two stage process. First the 
mask in the INTERRUPT MASK REGISTER must be 
enabled for each level of the interrupts used. Next, it is 
necessary to enable the individual transmit and receive 
interrupts. In the example program, a character is 
loaded into the transmit buffer and then the interrupt Is 
enabled by setting bit 2 in the UART INTERRUPT 
ENABLE (UIE) register. Each successive transmit inter- 
rupt indicates an empty buffer, and the next character is 
loaded into the buffer. When the last character is loaded 
into the buffer, the transmit interrupt is disabled to 
prevent further interruptions by clearing bit 2 of the UIE 
register. 

The receiver interrupt is enabled to allow the processor 
to accept incoming characters by setting bit of the UIE 
register. Once set, any received character will cause the 
processor to transfer control to the "RXDATI" routine. In 
this example, the receive service routine reads, echos, 
and stores each received character until a carriage 
routine is received. The input is then repeated. 

The example program does not fully utilize the Interrupt 
system, as it waits for each routine to complete before 
moving to the next. However, it does however work, and 
demonstrates interrupt service routines. Serial interrupt 
software is not complex, and could lead to very powerful 
user programs. With the addition of the on board DMA to 
automaticlly transfer characters, the Supers can com- 
plete many tasks that previously would require complex 
hardware and software. The next article in the series 
demonstrates using the DMA controller with the serial 
port. 
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, 1- , : 

.TITLE Sample Zilog Super 8 Serial Interrupt Mode Operation 



TITLE : 


UART2 . S 


DATE: 


JULY 17, 1986 


PURPOSE: 


TO DEMONSTRATE INTERRUPT 




DRIVEN SERIAL PORT 




COMMUNICATIONS 


ASSEMBLER: x 


ZILOG ASMS 8 ASSEMBLER 


PROGRAMMER: 


CHARLES M. LINK, II 



.PAGE 55 ;set maximum page size to 55 lines 

J *1citf********1cie*1c****it****if ****************** ********** ***** 
;* * 

;* GENERAL EQUATES * 

;* * 

************************************************************ 



OR: 
LF: 



.equ 
. equ 



OdH 
OaH 



; carriage return 
;line feed 



*********************************************************** 

* * 

* REGISTER EQUATE TABLE * 

* ,. * 
*********************************************************** 



period: .equ 

second : . equ 

minute : . equ 

hours: .equ 



; period timer 
; seconds timer 
; minutes timer 
; hours timer 



; working register equates 

MPTR: .equ RR8 ; message pointer for external memory 

*********************************************************** 

* ' * 

* INTERRUPT VECTOR TABLE * 

* * 
*********************************************************** 



INTRO: .WORD 

INTRl: .WORD 

1NTR2: .WORD 

INTR3: .WORD 

INTR4: .WORD 

INTR5: .WORD 

INTR6: .WORD 

INTR7: .WORD 

INTR8: .WORD 

.INTR9: .WQRD 

INTRIO: .WORD 

INTRl 1: .WORD 

INTRl 2: .WORD 

INTR13: .WORD 

INTR14: .WORD 

INTR15: .WORD 



INTRET 
INTRET 
INTRET 
INTRET 
INTRET 
INTRET 
TIMERO 
INTRET 
INTRET 
INTRET 
RXDATI 
INTRET 
INTRET 
TXDATI 
INTRET 
INTRET 



;this area should always be defined 
;as it reserves the lower 32 bytes 
;for the interrupt table, the name 
;of the subroutine for each particular 
; interrupt service would normally be 
; named here. 



J ********************* **-k*** ******* ************************* 
J* * 

;* START OF PROGRAM EXECUTION * 

;* * 

************************************************************ 
7 ■ 

START: jr STARTl ? program execution unconditionally 

; begins at this location after reset 
;and power up. 
.ASCII 'REL 7/17/86' ;jump around optional ascii string 

; containing release info, copyright, etc. 
STARTl: di /begin 

sbO /select register bank 
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Id 



Id 
Id 
Id 
Id 



EMT, #000000008 



PO,#OOH 

P0M,#11111111B 
PM, #001100008 
HlC, #000000008 



; external memory timing=no wait input, normal 

; memory timing, no wait states, stack internal, 

;and DMA internal 

? address begins at OOOOh, set upper byte 

; select all lines as address 

; enable port as upper 8 bits address 

; handshake not enabled port 



port 1 is defined in romless part as address/data, 
here to initialize that port 



it is not necessary 



Id 
Id 
Id 



Id 
Id 
Id 

Id 
Id 
Id 



P2,#00H ;port 2 outputs low 

P3,#00H ;port 3 outputs low 

P2AM, #100010108 ;p31,20,21 as output, p30 input 

;it is necessary here to configure p30 as input 
;for the receive data, and p31 as output for 
; transmit data for UART 

P28M, #101010108 ;p32,33,22,23 as output 

P2CM, #101010108 ;p34,35,24,25 as output 

P2DM, #101010108 ;p36,37,26,27 as output 

P4, #000000008 ;clear port 4 register 
P4D, #111111118 ;set all bitg of P4 as inputs 
P40D, #000000008 /active push/pull [not necessary since all 
; bits are inputs 



basic Super 8 I/O is initialized, now internal registers 

Id RPO,#OCOH ;set working register low to lower 8 bytes 
Id RP1,#0C8H ;set working register high to upper 8 bytes 
Id SPL,#OFFH ;set stack pointer to start at top of set two 
;note here that only lower 8 bits are used 
;for stack pointer, location OFFH is wasted 
;as stack operation. SPH is general purpose 
; storage . 

now clear the internal memory and stack area 



ZERO: 



Id 


SPH,#OF 


clr 


@SPH 


dec 


SPH 


jr 


nz , ZERO 


clr 


@SPH 



; point to top of general purpose register 
;zero it 

;do it until register set is all cleared 
;zero last register 



now everything except working registers is cleared 

cpu and memory now initialized, set up timer for real time clock 



Id 
Id 

Id 
sbl 
Id 
Id 



Id 



sbO 
Id 



;disable fast interrupt response 

/•interrupt priority 

;IRQ2>IRQ3>IRQ4>IRQ5>IRQ6>IRQ7>IRQ0>IRQ1 

; enable counter, rx and tx interrupts 

; select bank 1 

;high byte of time constant 
;low byte of time constant 

; 12, 000, 000 hertz / 4 / 50,000 = 60 hertz 

;12 Mhz is xtal freq, 4 is internal divider 

;p27,37 is I/O, programmed up/down, no capture 

; timer mode is selected 

/select bank 
COCT, #101001018 /continuous, count down, load counter, 

;zero count interrupt* enable, enable counter 



SYM, #000000008 
IPR, #000000108 

IMR, #010001108 

C0TCH,#^H8(50000) 
C0TCL,#^LB( 50000) 



COM, #000001008 



timer is set, now lets initialize the UART for polled operation 



sbl 
Id 



Id 
Id 
Id 



UMA, #011100008 



U8GH,#^H8(00009) 
U8GL,#^L8 (00009) 
UM8, #000111108 



;bank 1 

;time constant = (12,000,000/4/16/9600/2) -1= 
;8.76 rounded to 9. 

;note that a 12 Mhz does not make a very 
/accurate baud rate source, error is large 

/high byte of time constant 

/low byte of time constant 
/p21=p21data, auto-echo is off, transmit and 
/receive clock is baud rate generator output, 
/baud rate generator input is system clock / 2, 
/baud rate generator is enabled, loopback 
/is disabled 
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sbO ; select bank 

Id UTC, #100010008 ;select p31 as transmit data out, 1 stop bit 

;and transmit enable 
Id UIE, #000000008 ;no interrupts, no DMA 
Id URC, #000000108 ;enable receive 

;UART is initialized, enable interrupts for real time clock 

ei ; enable interrupts 

r 

;wait 1 full second of serial line mark before sending anything 



WAIT: 



cp 
jr 



second, #1 
ne , WAIT 



display the logon message 
LOGON: 



Idw 

call 

call 



MPTR,#MSG 

SENDM 

TXWAT 



;wait 1 second 



;load the address of MSG into word reg MPTR 

;send the message 

;wait for transmitter to complete 



logon message displayed, get response from console 
and move to upper register memory 



GET: 



Id 
Id 
di 
or 
ei 



rl,#80 ; maximum character count 

r2,#80H ;point to first location in upper register bank 

;stop interrupts 
UIE, #000000018 ;receive character enable 



; now wait for input to be completed 

GW: tm UI^, #000000018 ;wait for interrupt to be disabled 
jr nz,GW ;if interrupt still enabled 

if carriage return typed, or 80 characters exceeded, echo message 



ECHO: 



Idw 
call 



MPTR, #MSG1 
SENDM 



;load the address of MSGl in word reg MPTR 
;send the message 



since messages are interrupt driven, we must wait for message to 
complete before transmitting next message 



ECHOl: 



call 

Id 

Id 

Id 

call 

cp 

jr 

inc 

djnz 

jr 



subroutines 



TXWAT 
/rl,#80 
r2,#80H 
rO,§r2 
SENDC 
rO,#CR 
eq, LOGON 
r2 

rl, ECHOl 
LOGON 



;wait on transmitter 

/maximum character count 

; first location of character buffer 

;get character from buffer 

;send the character to console 

; carriage return? 

;if so, end message display 

;bump pointer 

; display next character if not done 



send message at MPTR until '$' 



SENDM: 



rO,eMPTR 
SENDC 

UIE, #000001008 



Idci 

call 

di 

or 

ei 

ret 
;send character in rO 
SENDC: tm UTC, #000000108 

jr z, SENDC 

Id UIO,rO 

ret 
; transmit buffer available interrupt 



character found 

;get the character 

; start UART transmitting 

;no interrupts 

; enable transmit interrupts 



; transmit buffer empty yet 

;if not, wait until it is 

;load the character into the transmitter 



TXDATI: Idci 

Id 

cp 

jr 

iret 
LASTT: and 

iret 

; transmitter wait routine 
TXWAT: tm .. UIE, #000001008 

jr nz, TXWAT 

ret 



rO,eMPTR 
UIO,rO 
rO,#'$' 
eq, LASTT 

UIE, #111110118 



rget next character to transmit 
;load the character in transmitter 
;last character 
;if last transmit character ^ 

; disable tra:nsmit interrupts 

; ignore it if no character to transmit 

;wait until interrupts disabled 
;wait if bit set 
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; receive character available interrupt 

RXDATI: Id rO,UIO ;get input from console 

and rO,#7fH ; remove upper parity bit 

call SENDC ;echo to console 

Id §r2,r0 ;move to upper internal ram in Supers 

cp rO,#CR ;was the received character a carriage return 

jr eq,LASTR ;if so, disable interrupts 

inc r2 ;bump pointer 

djnz rl,RXR ;exit if not last 

LASTR: and UIE, #111111108 ;disable the receive interrupts 
RXR: iret 

real time interrupt running in background 



TIMERO: inc 
cp 
jr 
xor 
clr 
inc 
cp 
jr 
xor 
clr 
inc 
cp 
jr 
xor 
clr 
inc 
cp 
jr 
clr 

NOROLL: or 
nop 
nop 

INTRET: iret 



MSG: 



MS61: 
.END 



.ASCII 
•ASCII 
.ASCII 



period 

period, #60 

ne, NOROLL 

P2,#00000001B 

period 

second 

second, #60 

ne, NOROLL 

P2,#00000010B 

second 

minute 

minute, #60 

ne, NOROLL 

P2, #000001008 

minute 

hours 

hours, #24 

ne, NOROLL 

hours 

COCT, #000000108 



;bump periodic counter (60 hertz) 

?one second yet? 

?no rollover 

; complement the second bit 

? start it over again 

rbump the seconds timer 

r reached maximum 

fno rollover 

; complement the minute bit 

? start it over again 

;buiap the minutes timer 

preached maximum 

?no rollover 

f complement the hour bit 

? start it over again 

rbump the hours timer 

r reached maximum 

mo rollover 

r start it over again 

? reset end of count 



;and return from interrupt 



CR,LF, 'Supers Uart test program. ' ,CR,LF 

•Enter up to one full line followed by return' ,CR,LF, •$' 

CR,LF, 'Echoed back, your line was. . . ' ,CR,LF, '$' 
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USING THE SUPER8 
SERIAL PORT WITH DMA 

by Charles M. Link, II 



With the increasing integration available today, 
microprocessor manufacturers are incorporating new 
peripherals that typically were off board in previous 
products, and sometimes required a large amount of ex- 
ternal logic to utilize. The direct memory access function 
is a good example. Zilog has incorporated a very power- 
ful DMA in the new SuperS microcontroller. It has the 
capability of linking to several on board peripherals, in- 
cluding the serial port, and can control data transfers to 
the different memory mediums. 

The Supers, with its on-board DMA can reduce proces- 
sor overhead in data transfer tasks. It allows direct 
transfer of serial input characters to either internal 
register memory (256 bytes) or external ram memory. 
For example, this transfer can be set to transfer a 
specific number of input characters, then interrupt the 
processor. Processor program service overhead is mini- 
mal. Serial output characters can be transfered from ex- 
ternal EPROM or ram memory, or the internal register 
memory. 

The required setup for the DMA transfers are much the 
same as that of interrupt or polled operation. This 
proigram example uses the DMA to interrupt upon ter- 
mination of data transfers so that approopriate vectors 
and routines are required. Since the program links to the 
serial port, the DMA uses the serial port receive and 
transmit interrupt vectors 10 and 13, respectively. Upon 
completion of a receive DMA transfer, the service routine 
defined by the receive vector is executed. Upon comple- 
tion of the transmit DMA transfer, service routine defined 
by the transmit vector is executed. 

It is necessary to define the memory source/destination 
by setting the appropriate state of bit in the EXTERNAL 
MEMORY TIMING (EMT) register, jnitially, the example 
program selects external memory as the source/destina- 
tion. A special note: read the fine print In the technical 
manual. Many hours were spent debugging the DMA 
mode of operation, with the final realization that internal 
rom does not qualify as external memory. Only that 
memory that would be selected if the /DM line was true 
would be a valid source/destination. Since this article 
uses the hardware defined from the first of the series, 
and uses a Z8800 with external EPROM, it will work per- 
fectly. ROM and PIGGYBACK or prototype type parts 
will not work. Neither will emulators. 



This sample uses the DMA mode to transmit a few lines 
of ASCII data to a console. The DMA requires a total 

byte count to property transfer the data and terminate. 
Be careful to recognize that the ASCIL pseudo-op in the 
Zilog assembler, or many other assemblers. Is not an 
easy way to generate the byte count. Warning! The 
Zilog assembler generates a length for each subgroup, 
e.g., "MSG" generates a separate length for each group 
separated by commas, not one total length. 

Initially, the DMA transfers from EPROM. The address 
from which to transfer Is CO and CI as defined by the 
working register pointers. It is necessary to set RPO to 
CO to access the register, and it is accessed as RO and 
R1 or RRO. The count for the transfer is taken from DMA 
COUNT HIGH and DMA COUNT LOW. For each trans- 
fer, initialize the address and count values. Upon com- 
pletion of the DMA transmit process, when the count 
goes to -1, a transmit Interrupt is generated. The ex- 
ample program disables transmit interrijpts and DMA, 
and returns. The main line program was polling the inter- 
rupt enable bit for completion. 

Next, the DMA is set up to transfer 25 characters into the 
internal register memory. One must select internal 
memory in the EMT register by clearing bit 0. The ad- 
dress for transfer requires only one byte, so that working 
register 1 (R1), when RPO equals CO, is the address 
pointer. The DMA count must also be loaded, in this 
case with 25. For demonstration purposes, the auto- 
echo bit of the UART MODE B register is selected. This 
causes any characters received to be automatically 
looped back to the transmit port. Finally, the receive in- 
terrupt and DMA enable bits (BITS and 1 ) are set to 
enable and begin DMA operation. When 25 characters 
have been input to the Supers, a receive interrupt will be 
generated, and control will be transfered to the "RXDATI" 
routine, where interrupts and DMA are disabled. 

The last routine in the example software sends another 
message from EPROM to the console and then sends 
the characters from the internal memory buffer that were 
previously entered. The prime consideration is to 
remember to select the source/destination memory in the 
EMT register. 

In this DMA example, the code is simple for DMA opera- 
tion. It is important to note that this example does not 
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fully utilize the functionality of the DMA transfer. The ex- 
ample purposely waits in a software loop while the DMA 
transfer occurs. This prevents the supporting code from 
becoming too complex to follow for an example. Normal 
operation might have the UART receiving characters 



under DMA controls and transmitting characters under 
interrupt control with processirig occurring somewhere in 
the middle. 



.TITLE Sample Zilog Super 8 Serial DMA Mode Operation 



TITLE: 


UART3 . S 


DATE: 


JULY 17, 1986 


PURPOSE: 


TO DEMONSTRATE DMA 




DRIVEN SERIAL PORT 




COMMUNICATIONS 


ASSEMBLER: 


ZILOG ASMS 8 ASSEMBLER 


PROGRAMMER: 


CHARLES M. LINK, II 



.PAGE 55 ;set maximum page size to 55 lines 

;1i***it1e*1t1ci(1t *********************************** 1c************ 

;* * 

;* GENERAL EQUATES * 

;* * 

;*********************************************************** 

CR: .equ OdH ; carriage return 
LF: .equ OaH ;line feed 

*********************************************************** 

* * 

* REGISTER EQUATE TABLE * 

* * 
*********************************************************** 



period: 


.equ 





; period timer 


second: 


.equ 


1 


; seconds timer 


minute : 


.equ 


2 


; minutes timer 


hours : 


.equ 


3 


; hours timer 



; working register equates 

MPTR: .equ RRO ; message pointer for external memory 

************************************************************ 
J* * 

;* INTERRUPT VECTOR TABLE * 

;* * 

************************************************************ 



;this area should always be defined 
;as it reserves the lower 32 bytes 
;for the interrupt table, the name 
;of the subroutine for each particular 
; interrupt service would normally be 
; named here. 



INTRO: 


.WORD 


INTRET 


INTRl: 


.WORD 


INTRET 


INTR2 : 


.WORD 


INTRET 


INTR3 : 


.WORD 


INTRET 


INTR4 : 


.WORD 


INTRET 


INTR5: 


.WORD 


INTRET 


INTR6 : 


.WORD 


TIMERO 


INTR7 : 


.WORD 


INTRET 


1NTR8 : 


.WORD 


INTRET 


INTR9 : 


.WORD 


INTRET 


INTRIO: 


.WORD 


RXDATI 


INTRl 1: 


.WORD 


INTRET 


INTR12 : 


.WORD 


INTRET 


INTRl 3 : 


.WORD 


TXDATI 


INTR14 : 


.WORD 


INTRET 


INTRl 5: 


.WORD 


INTRET 



************************************************************ 
J* * 

;* START OF PROGRAM EXECUTION * 

;* * 

************************************************************ 



START: jr 



STARTl 



; program execution unconditionally 
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; begins at this location after reset 
;and power up. 
.ASCII 'REL 1/n/^S* ;jump around optional ascii stririg 

; containing release info, copyright, etc. 
STARTl: di ; begin 

; select register bank 

; external memory timing=no wait input, normal 

; memory timing, no wait states, stack internal, 

;and DMA external 

; address begins at OOOOh, set upper byte 

; select all lines as address 

; enable port as upper 8 bits address 

/handshake not enabled port 



di 

sbO 

Id 



Id 
Id 
Id 
Id 



EMT,#00000001B 



PO,#OOH 

P0M,#11111111B 
PM, #001100003 
H1C,#00000000B 



port 1 is defined in romless part as address/data, 
here to initialize that port 



it is not necessary 



Id 
Id 
Id 



Id 
Id 
Id 

Id 
Id 
Id 



;port 2 outputs low 
;port 3 outputs low 
P2AM, #100010108 ;p31,20,21 as output, p30 input 

;it is necessary here to configure p30 as input 

;for the receive data, and p31 as output for 

; transmit data for UART 

;p32,33,22,23 as output 

;p34,35,24,25 as output 

;p36,37,26,27 as output 



P2,#00H 
P3,#00H 



P2BM, #101010103 
P2CM, #101010103 
P2DM, #101010103 



P4, #000000003 ;clear port 4 register 
P4D, #111111113 ;set all bits of P4 as inputs 
P40D, #000000003 ;active push/pull [not necessary since all 
; bits are inputs 



basic Super 8 I/O is initialized, now internal registers 

Id RPO,#OCOH ;set working register low to lower 8 bytes 
Id RP1,#0C8H ;set working register high to upper 8 bytes 
Id SPL,#OFFH ;set stack pointer to start at top of set two 
;note here that only lower 8 bits are used 
;for stack pointer, location OFFH is wasted 
;as stack operation. SPH is general purpose 
; storage . 

now clear the internal memory and stack area 



ZERO: 



Id 


SPH, # OFFH 


clr 


§SPH 


dec 


SPH 


jr 


nz , ZERO 


clr 


§SPH 



;point to top of general purpose register 
;zero it 

;do it until register set is all cleared 
;zero last register 



now everything except working registers is cleared 

cpu and memory now initialized, set up timer for real time clock 



Id 
Id 

Id 
sbl 
Id 
Id 



Id 



SbO 
Id 



; disable fast interrupt response 

; interrupt priority 

;IRQ2>IRQ3>IRQ4>IRQ5>IRQ6>IRQ7>IRQ0>IRQ1 

; enable counter, rx and tx interrupts 

; select bank 1 

;high byte of time constant 
;low byte of time constant 

?12,000,000 hertz / 4 / 50,000 = 60 hertz 

;12 Mhz is xtal freq, 4 is internal divider 

;p27,37 is I/O, programmed up/down, no capture 

; timer mode is selected 

; select bank 
COCT, #101001013 ; continuous, count down, load counter, 

;zero count interrupt enable, enable counter 



SYM,#00000000B 
IPR, #000000103 

IMR, #010001108 

C0TCH,#^HB(50000) 
C0TCL,#^L3(50000) 



COM, #000001003 



timer is set, now lets initialize the UART for polled operation 



sbl 
Id 



UMA, #011100003 



rbank 1 

;time constant = (12, 000,000/4/16/9600/2) -1= 
;8.76 rounded to 9. 

;note that a 12 Mhz does not make a very 
/accurate baud rate source, error is large 
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Id 
Id 
Id 



sbO 
Id 



Id 
Id 



UBGH,#^HB(00009) ;high byte of time constant 
UBGL, #^LB(00009) ;low byte of time constant 
UMB,#00011110B ;p21=p21data, auto-echo is off, transmit and 
; receive clock is baud rate generator output, 
;baud rate generator input is system clock / 2, 
;bau4 rate generator is enabled, loopback 
;is disabled 
; select bank 
UTC,#10001000B ;select p31 as transmit data out, 1 stop bit 

;and transmit enable 
UIE,#00O000O0B ;no interrupts, no DMA 
URC,#00000010B ;enable receive 



;UART is initialized, enable interrupts for real time clock 

ei ; enable interrupts 

because uart was just enabled, allow data line to mark for at least 1 second 



WAIT: 



qp 

jr 



second, #1 
ne,WAIT 



display the logon message 



LOGON: 



Idw 

call 

call 



MPTR, #MSG 

SENDM 

TXWAT 



;wait 1 second 



;load the address of MSG into word reg MPTR 

;send the message 

;wait for transmitter to complete 



logon message displayed, get response from console 
and move to upper register memory 

GET: di ;no interrupts while setting up for DMA 

Idw MPTR,#0080H ; first character receive location 

and EMT,#11111110B ;select register file for receiving character 
sbl /select bank one 

Id DCH,#0 ;DMA count high byte 

Id DCL,#25 ;DMA count low byte 

or UMB,#00100000B ;auto echo enable 
sbO /restore to bank zero 

or UIE,#00000011B /receive character DMA link, interrupt enable 
ei 

call RXWAT ;wait for receiver to complete receiving input 

receive characters in buffer, restore Supers non DMA state 



di 

sbl 

and 

SbO 

or 

ei 



UMB, #110111118 
EMT,#00000001B 



;no interrupts while cleaning up 

;bank 1 

/disable auto echo 

/ restore bank 

/select data memory for DMA transfers 



25 characters received via DMA, now display "ECHO" message 

ECHO: Idw MPTR,#MSG1 /load the address of MSGl in word reg MPTR 
call SENDM /send the message 

call TXWAT /wait on transmitter 

message sent, now replay typed input 



di 

Idw 

and 

sbl 

Id 

Id 

SbO 

or 

or 

ei 

call 

di 

or 

ei 



MPTR,#0080H /point to beginning of buffer 
EMT,#11111110B /select register bank for DMA transfer 

/select bank 1 
DCH,#0 /DMA count high byte 

DCL,#25 /DMA count low byte 

/select bank ^ 
UIE,#00000100B /enable transmit interrupts 
UTC,#00000001B /transmit DMA enable 

/enable interrupts 
TXWAT /wait on transmitter 

EMT,#00000001B /select external data memory for DMA transfer 



replay complete, loop back and do it again 
jr LOGON 
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subroutines 

send message at MPTR for length in first byte 



r7 , @MPTR 
r7 

EMT, #000000016 

DCH,#0 
DCL,r7 

UIE,#00000100B 
UTC,#00000001B 



SENDM: Idci 

dec 

di 

or 

sbl 

Id 

Id 

sbO 

or 

or 

ei 

ret 
; transmit DMA complete 
TXDATI: and UIE, #111110118 

and UTC, #111111108 

iret 
; transmitter wait routine 
TXWAT: tm UIE, #000001008 

j r nz , TXWAT 

ret 
; receive character available interrupt 
RXDATI: and UIE, #111111008 ;disable the receive interrupts 

iret 
/•receive wait routine 
RXWAT: tm UIE, #000000018 ;wait until interrupts disabled 

jr nz, RXWAT ;wait if bit still set 

ret 

real time interrupt running in background 



;get the character 

; count actually should be n-1 for n bytes 

;no interrupts while setting up 

; select external data memory for DMA transfer 

; select bank 1 

;DMA cbunt high byte is 

;move the count DMA count low byte 

; select bank 

; enable transmit interrupts 

; transmit DMA enable 



; disable transmit interrupts 

/•disable transmit DMA 

/•ignore it if no character to transmit 



;wait until interrupts disabled 
;wait if bit set 



TIMERO: inc 
cp 
jr 
xor 
clr 
inc 
cp 
jr 
xor 
clr 
inc 
cp 
jr 
xor 
clr 
inc 
cp 
jr 
clr 

NOROLL: or 
nop 
nop 
iret 



INTRET: 



MSG: 



MSGl: 



period 

period, #60 

ne, NOROLL 

P2, #000000018 

period 

second 

second, #60 

ne, NOROLL 

P2, #000000108 

second 

minute 

minute, #60 

ne, NOROLL 

P2, #000001008 

minute 

hours 

hours, #24 

ne, NOROLL 

hours 

COCT, #000000108 



;bump periodic counter (60 hertz) 

;one second yet? 

;no rollover 

; complement the second bit 

; start it over again 

;bump the seconds timer 

/•reached maximum 

;no rollover 

/•complement the minute bit 

/•start it over again 

/•bump the minutes timer 

/•reached maximum 

/•no rollover 

/•complement the hour bit 

/•start it over again 

/•bump the hours timer 

/•reached maximum 

/•no rollover 

/•start it over again 

/•reset end of count 



;and return from interrupt 



.8YTE 56 

.ASCII CR,LF, 'Supers Uart DMA test program. • ,CR,LF 

.ASCII 'Enter 25 characters' ,CR,LF, ' $• 

.8YTE 34 

.ASCII CR,LF, 'Echoed back, your line was. . . ' ,CR,LF, '$' 
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GENERATING SINE WAVES 
WITH THE ZILOG SUPERS 

by Charles M. Link, II 



Generally digital microprocessors are thought of as only 
being able to generate digital signals.. .that is either on or 
off. With the simple addition of a digital-to-analog con- 
verter (DAC), more complex waveforms may be 
generated. Since the advent of the microprocessor and 
the DAC, many methods have been used by hardware 
and software designers to generate sine waves, includ- 
ing some that involve precise instruction and clock cycle 
calculations. This example is different. 

The Zilog Supers microcomputer is a single chip device 
requiring only a latch and EPROM to operate in its ROM- 
LESS state. Leaving 24 I/O lines for user configuration, 
it is extremely easy to interface with peripherals, includ- 
ing, in this case, the DAC- 08. The hardware in this ap- 
plication example is essentially the same base hardware 
as the previous application articles. Since it is assumed 
that the reader has access to those articles, detailed ex- 
plaination of the base will not be made here. Only the 
additions to the base will be explained. 

The base SuperB microprocessor has ports 2, 3 and 4 
available for user connection. For this example, the 
DAC-08 Is connected to port 4 (P4). The DAC-08 is tied, 
with the least significant bit tied to P40 and the most sig- 
nificant bit tied to P47. The other connections to the 
DAC-08 are mostly out of the test circuit description 
shown in the data manuals associated with it. The DAC 
requires -1 2 volts for proper operation. The output for 
this example is tied to a simple op- amp filter with a 
sharp roll off at about 3500 hertz. This type filter might 
be quite suitable for telecommunications applications, but 
may not be so good for many others. An oscilloscope 
displays the resultant waveform. 

The software to operate the Super8 is in the original in- 
itialization software from eariier in this article series. In- 
itialization is essentially the same. Port 4 must be set up 
as output, with active push-pull drivers. The main con- 
sideration for this program is the software "sample" rate. 
For this example, 8000 samples per second was chosen. 
Any other rate may be chosen, and the author has suc- 
cessfully used values up to 16000 samples per second 
without timing problems. Higher base clock rates are 
possible with the recently introducecd 20 megahertz 
Super8 chips available. With the sample method used, 
the sample rate does not vary with the different sine 
wave frequencies generated. 



The sample method requires a sine wave table stored in 
ROM or EPROM. This example uses 256 values, al- 
though 64, 128 or more values are quite acceptable. 
The BASICA program that generated the sine table is in- 
cluded for user modification. Once the values were 
generated, they were manually typed into the program. 
Using the Zilog macro assembler would have signigicant- 
ly slowed assembling. Note that the comments in the 
BASICA program imust be removed before the PC can 
execute. 

The values generated by the BASICA program are 
values ranging from 01 H to OFEH. Since the DAC repre- 
sents OOH as zero volts and OFFH as 5 volts, this table 
will product sine outputs from almost zero to almost five 
volts. 

The principle of operation requires that a sixteen bit fre- 
quency increment be maintained. This increment is 
generated by the simple formula 



FREQUENCY INCREMENT 
QUENCY)/ SAMPLE 



(TABLESTEP X 256 X FRE- 



where FREQUENCY INCREMENT is a sixteen bit value 
saved in an increment register, TABLESTEP is the num- 
ber of values in the sine wave table, FREQUENCY is the 
desired frequency of generation in hertz, and SAMPLE is 
the number of samples per second. In the example 
program, this increment is stored in "FINCR". 

A current offset into the sine table is maintained in the 
register pair labeled "INCR". At each periodic interrupt, 
FINCR must be added to INCR and saved in INCR. This 
sixteen bit value remains the offset into the table. The 
upper byte of the offset is used to point to the value in 
the 256 byte sine table that is loaded into the DAC. In 
the sample program, the value loaded into the DAC is 
generated in the previous interrupt and saved until the 
first instruction of the next interrupt. This allows the inter- 
rupt to perfomi some other varying length transactions, 
without introducing bit jitter into the sine wave. 

Changing the "FINCR" by program control causes dif- 
ferent frequencies to be generated. In this case, the sine 
wave may be turned off by disabling the counter inter- 
rupt. Depending upon the number of steps in the sine 
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table and the sample frequency, very accurate sine fre- 
quencies may be generated. Calculate the actual error 
by using the following formula: 

[ ABS { REAL FREQI - INTEGER FREQI) / REAL FREQI ] X 
100 = % ERROR 

where REAL FREQI is the actual calculated frequency 
increment, INTEGER FREQI is the nearest rounded in- 
teger of the calculated frequency Increment, and the 
result is the actual percent en'orform the desired value. 



With the addition of a filter with sharp cutoff just above 
the highest desired frequency, the Supers serves quite 
well as a programmable sinfe wave generator. In addition 
to sine waves, complex waveforms may be easily 
generated by the Supers with the addition of the low-cost 
DAC. The next article in this series will describe how to 
generate some of these more complex waveforms. 



.TITLE Supers Example Sine Wave Generation 



TITLE: 


SINE.S 


DATE: 


JUNE 17, 1986 


PURPOSE: 


TO DEMONSTRATE USING SUPERS 


■' 


TO GENERATE HIGH QUALITY SINE 




WAVES . 


HARDWARE: 


DAC-08 ON PORT 4 




SEE DIAGRAM 


ASSEMBLER: 


ZILOG ASMSS ASSEMBLER 


PROGRAMMER: 


CHARLES M. LINK, II 



. PAGE 55 



;set maximum page size to 55 lines 



J *1c*1t1titit*1e1t1t*itit*****1c**it ********************** ^it-k-k-k********* 

J* * 

?* REGISTER EQUATE TABLE * 

;* * 

************************************************************ 

/current increment in sine table 
;high byte of current increment value 
;low byte of current increment value 
; increment in sine table for frequency 
;high byte of frequency increment value 
;low byte of frequency increment value 
; pointer into sine table 
;high byte of sine table pointer 
;low byte of sine table pointer 
/current value to output to DAC-08 

************************************************************ 
;* * 

;* GENERAL EQUATES * 

• * * 

************************************************************ 



INCR: 


.equ 


rrO 


INCRH: 


.equ 


rO 


INCRL: 


.equ 


rl 


FINCR: 


.equ 


rr2 


FINCRH: 


.equ 


r2 


FINCRL: 


.equ 


r3 


POINT: 


• equ 


rr4 


POINTH: 


.equ 


r4 


POINTL: 


.equ 


r5 


CVAL: 


.equ 


r6 



XTAL: .equ 

SAMPLE: .equ 

CTVAL: .equ 

TABSTP: .equ 

FREQ : . equ 

FREQI : . equ 



12000000 

8000 

XTAL/4/SAMPLE 

256 
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/crystal freq in hertz 
/sample frequency in hertz 
/counter load value 
/number of values in sine table 
/desired sine wave frequency 



(TABSTP*256*FREQ) /SAMPLE 
*********************************************************** 



y* INTERRUPT VECTOR TABLE j * 

;* * ' 

************************************************************ 

/this area should always be defined 
/as it reserves th^ lower 32 bytes 
/for the interrupt table, the name 
/of the subroutine for each particular 
/interrupt service would normally be 
/named here. 



INTRO : 


.WORD 


INTRET 


INTRl : 


.WORD 


INTRET 


INTR2: 


.WORD 


INTRET 


INTR3: 


.WORD 


INTRET 


INTR4 : 


.WORD 


INTRET 


INTR5 : 


.WORD 


INTRET 


INTR6: 


.WORD 


TIMERO 


INTR7 : 


.WORD 


INTRET 
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INTR8: 


.WORD 


INTRET 


INTR9: 


.WORD 


INTRET 


INTRIO: 


.WORD 


INTRET 


INTRll: 


.WORD 


INTRET 


INTR12 : 


.WORD 


INTRET 


INTR13: 


.WORD 


INTRET 


INTR14 : 


.WORD 


INTRET 


INTR15: 


.WORD 


INTRET 



;* * 

;* START OF PROGRAM EXECUTION * 

;* * 

START: jr STARTl ; program execution unconditionally 

; begins at this location after reset 

;and power up. 
.ASCII 'REL 6/16/86* ;juinp around optional ascii string 

/containing release info, copyright, etc. 
STARTl; di ; begin 

sbO ; select register bank 

Id EMT, #000000006 /external memory timingB=no wait input, normal 

/memory timing, no wait states, stack internal, 

;and DMA internal 
Id PO,#OOH /addibess begins at OOOOh, set upper byte 
Id POM, #111111118 /select all lines as address 
Id PM, #001100006 /enable port as upper 8 bits address 
Id HlC, #000000006 /handshake not enabled port 

port 1 is defined in romless part as address/data, it is not necessary 
here to initialize that port 

Id P2,#00H /port 2 outputs low 

Id P3,#00H /port 3 outputs low 

Id P2AM, #101010106 /p30,31,20,21 as output 

Id P26M, #101010106 /p32, 33,22,23 as output 

Id P2CM, #101010106 /p34,35,24,25 as output 

Id P2DM, #101010106 /p36, 37,26,27 as output 

Id P4, #100000006 /set midpoint for DAC inputs 
Id P4D, #000000006 /set all bits of P4 as output 
Id P40D, #000000006 /active push/pull 

basic Super 8 I/O is initialized, now internal registers 

Id RPO,#OCOH /set working register low to lower 8 bytes 
Id RP1,#0C8H /set working register high to upper 8 bytes 
Id SPL,#OFFH /set stack pointer to start at top of set two 
/note here that only lower 8 bits are used 
/for stack pointer, location OFFH is wasted 
/as stack operation. SPH is general purpose 
/storage. 

now clear the internal memory and stack area 

/point to top of general purpose register 
ZERO: clr §SPH /zero it 



Id 


SPH, # OFFH 


clr 


esPH 


dec 


SPH 


ir 


nz,ZERO 


clr 


esPH 



/do it until register set is all cleared 
/zero last register 

now everything except working registers is cleared 

cpu and memory now initialized, set up timer for real time clock 

Id SYM, #000000006 /disable fast interrupt response 
Id IPR, #000000106 /interrupt priority 

/IRQ2>IRQ3>IRQ4>IRQ5>IRQ6>IRQ7>IRQ0>IRQ1 
Id IMR, #000001006 /enable only interrupt 2 
sbl /select bank 1 

Id C0TCH,#^H6(CTVAL) /high byte of time constant 
Id COTCL,#^Le(CTVAL) /low byte of time constant 
Id COM, #000001006 /p27,37 is I/O, programmed up/down, no capture 

/timer mode is selected 
sbO /select bank 

Id COCT, #101001016 /continuous, count down, load counter. 
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;zero count interrupt enable, enable counter 



;timer is initialized, now lets enable interrupts and wait 





Idw 


INCR, #1 




Idw 


FINCR, #FREQI 




Idw 


POINT, #SINTAB 




Id 


CVAL, #08 OH 




ei 




WAIT: 


nop 
nop 
nop 
nop 






jr 


WAIT 



; Start at the beginning of sine table 

;load frequency of increment 

; pointer points to sine table 

/initial value to ppevent glitch at start 

/enable interrupts 



;loop back 

;Timer interrupt. Occurs SAMPLE times per second 

; interrupt outputs value to DAC-08 and then determines value for next 

/interrupt. This assures no bit jitter. 

/write new value to DAC-08 

/clear carry flag 

/find next position in sine table 

/by adding frequency offset to last position 

/set new pointer into sine table 

/upper byte ok since on boundary 

/get value from sine table 

/reset end of count interrupt 

/and return from interrupt 

******************************************************* ***^ 

* * 

* SINE WAVE LOOKUP * 

* * 
*********************************************************** 

sine table for sine wave generation using DAC-08. Table based upon 
case of waveform with minumum amplititude = volts and maximum 
amplititude *= 5 volts. DAC-08 input for volts = OOH 
5 volts == OFFH. Table generated using following BASICA program, 
then typed into program. 



TIMERO : 


Id 
rcf 


p4,CVAL 




add 


INCRL, FINCRL 




adc 


INCRH,FINCRH 




Id 


POINTL, INCRH 




Idc 


CVAL, @POINT 




or 


cocT, #000000: 


INTRET: 


iret 





10 CLS 

20 PI=3. 141593 

30 FOR 1=0 TO 255 

40 C=360/256 

50 D=C*I 

60 E=D*PI/180 

70 F«SIN(E) 

80 G«F*127 

90 H=128+G 

100 J=CINT(H) 

110 A$'=HEX$(J) 

120 PRINT A$ 

130 LPRINT A$ 

140 NEXT 

150 END 



/clear screen 

/define PI 

/256 total values 

/define basic intejrval value 

/value from zero on sine wave 

/figure sine for interval from 

/sine range should be from -127 to 127 

/make result from to 255 

/round to nearest integer 

/convert to hex 

/on screen 

/on printer 

/do next inverval 



*note-remove comments, BASICA will not accept / as comment delimiter 



/begin sine table on even byte boundary 
089H, 08CH, 090H, 093H, 096H, 099H, 09CH, 09FH, 0A2H 
OAEH, OBIH, 0B3H, 0B6H, 0B9H, OBCH, OBFH, OCIH, 0C4H 
OCEH, ODIH, 0D3H, 0D5H, 0D8H, ODAH, ODCH, ODEH, OEOH 
0E8H, OEAH, OEBH, OEDH, OEFH, OFOH, OFIH, 0F3H, 0F4H 
0F9H, OFAH, OFAH, OFBH, OFCH, OFDH, OFDH, OFEH, OFEH 
OFFH , OFFH , OFFH , OFFH , OFFH , OFEH , OFEH , OFEH , OFDH 
OFAH, OFAH, 0F9H, 0F8H, 0F6H, 0F5H, 0F4H, 0F3H, OFIH 
OEBH , OEAH , 0E8H , 0E6H , 0E4H , 0E2H , OEOH , ODEH , ODCH 
0D3H, ODIH, OCEH, OCCH, 0C9H, 0C7H, 0C4H, OCIH, OBFH 
0B3H, OBIH, OAEH, OABH, 0A8H, 0A5H, 0A2H, 09FH, 09CH 



SINTAB: .ORG 


0400H 


.byte 


080H,083H,086H, 


.byte 


0A5H,0A8H,0ABH, 


.byte 


0C7H,0C9H,0CCH, 


.byte 


0E2H,0E4H,0E6H, 


.byte 


0F5H,,0F6H,0F8H, 


.byte 


OFEH, OFFH, OFFH, 


.byte 


OFDH, OFCH, OFBH, 


.byte 


OFOH, OEFH, OEDH, 


.byte 


0DAH,0D8H,0D5H, 


.byte 


0BCH,0B9H,0B6H, 
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.byte 099H, 096H, 093H, 090H, 08CH, 089H, 086H, 083H, 080H, 07DH, 07AH, 077H 

.byte 074H, 070H, 06DH, 06AH, 067H, 064H, 061H, 05EH, 05BH, 058H, 055H, 052H 

.byte 04FH, 04DH, 04AH, 047H, 044H, 041H, 03FH, 03CH, 039H, 037H, 034H, 032H 

.byte 02FH, 02DH, 02BH, 028H, 026H, 024H, 022H, 020H, OlEH, OICH, OlAH, 018H 

.byte 016H, 015H, 013H, OllH, OlOH, OOFH, OODH, OOCH, OOBH, OOAH, 008H, 007H 

.byte 006H, 006H, 005H, 004H, 003H, 003H, 002H, 002H, 002H, OOIH, OOIH, OOIH 

.byte OOIH, OOIH, OOIH, OOIH, 002H, 002H, 002H, 003H, 003H, 004H, 005H, 006H 

.byte 006H, 007H, 008H, OOAH, OOBH, OOCH, OODH, OOFH, OlOH, OllH, 013H, 015H 

.byte 016H, 018H, OlAH, OICH, OlEH, 020H, 022H, 024H, 026H, 028H, 02BH, 02DH 

.byte 02FH, 032H, 034H, 037H, 039H, 03CH, 03FH, 04iH, 044H, 047H, 04AH, 04DH 

.byte 04FH, 052H, 055H, 058H, 05BH, 05EH, 061H, 064H, 067H, 06AH, 06DH, 070H 

.byte 074H,077H,07AH,07DH 

. END 
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^ZilGG 



Application Note 



August 1987 



GENERATING DTMF TONES 
WITH THE ZILOG SUPERS 

by Charles M. Link, II 



In the previous article, a sine wave generation example 
was demonstrated. Sine waves are great, but, some- 
times, more complex waveforms must be generated. 
One of the most widely used complex waveforms is the 
DTMF tone. The DTMF tone is used on millions of 
telephones under the AT&T registered name "TOUCH 
TONE". Generally, telecommunications designers pur- 
chase one of the many DTMF encoder chips and hang it 
beside a microprocessor. This application article con- 
tains an example of a DTMF generation scheme that 
produces nearly as pure and probably as accurate a tone 
as the external chip method. 

Generating sine waves requires some type of digital-to- 
analog converter to interface to the microprocessor. For 
this application, a DAC-08 is used. This DAC-08 is tied 
to port 4 of the Super8. Since it is assumed that the 
reader has access to the previous article, a detailed 
description of the hardware will be left to that article. 
Why not use the DTMF generator chip, when it might be 
just as inexpensive as the DAC- 08? The answer is that 
the DTMF generator chip requires an external crystal or 
clock, and it might not be convenient to pick a processor 
frequency that is a direct multiple of the one required by 
the generator. The second and more important reason is 
that the DAC-08 can be used to generate other call 
progress tones such as ringback and busy, or any other 
complex waveform. 

Since the previous article discussed the method for 
generating sine wave tones, this article will only discuss 
how to turn that into the DTMF tone. The DTMF tone is 
actually a combination of two tones, hence, the name 
DUAL TONE MULTI-FREQUENCY. The tones are ar- 
ranged such that each row and each column has a cor- 
responding single frequency tone assigned. An 
additional, normally unseen column, contains an eighth 
tone frequency. A simple diagram below shows the ar- 
rangement. 

DTMF TONE ASSIGNMENT 



697 
770 
852 
941 



1209 


1336 


1477 


1633 


1 


2 


3 


A 


4 


5 


6 


B 


7 


8 


9 


C 


* 





# 


D 



The method used to combine the two tones into one 
single complex waveform is simple: add the two in- 
dividual tones together. Adding the tones together is 

usually what happens when analog circuitry produces the 
DTMF tone. In fact, most of the DTMF encoder chips 
usually add the tones together either Internally or exter- 
nally to produce the single waveform. 

Generating the two tones is no task for the Super8 
microcomputer. Just set up two cun-ent table offset 
values and two different frequency increments. At each 
periodic interrupt the 16 bit frequency increment is added 
to the current table offset producing a new current table 
offset. The upper byte of jeach current table offset (one 
for the row frequency and one for the column) is used as 
a pointer into a 256 byte table. The sine values retrieved 
from the table are then added together and loaded into 
the DAC-08. 

Since the DAC input of OOH corresponds to an output of 
volts and the Input of OFFH corresponds to an output of 
5 volts, adding two values that could possibly be OFFH 
presents a problem. Since two sines must add to no 
more 5 volts, the maximum for one single sine value 
must be one half of 5 volts, or 80H. The sine table has 
been adjusted so that the 2.5 volt value is mid-range. 
The maximum or mimumum for the sine wave is plus or 
minus 1 .25 volts. 

The interrupt service routine Is almost exactly the same 
as the interrupt routine for the sine wave, except that two 
sine waves are calculated. The final values are added 
together and stored for the first instruction of the next in- 
terrupt. In order to change tones, or disable the tone 
generation, additional software logic could enable or dis- 
able the interrupt, and modify the two values "CINCR", 
and "RINCR". 

It is clear from the example, that ringback, busy, MF, and 
other signaling tones can be easily generated without ad- 
ditional hardware. Increased sampling rates could be 
used to generate tones of much higher frequencies and 
accuracies. The accuracy, using the above method and 
sampling frequencies, is much less than one percent, to- 
tally suitable for telecommunications needs. 
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.TITLE Supers Example DTMF Generation 



TITLE: 


DTMF.S 


DATE: 


JUNE 17, 1986 


PURPOSE: 


TQ DEMONSTRATE USING SUPERS 




TO GENERATE HIGH QUALITY DTMF 




WAVES . 


HARDWARE: 


DAC-08 ON PORT 4 




SEE DIAGRAM 


ASSEMBLER: 


ZILOG ASMSS ASSEMBLER 


PROGRAMMER: 


CHARLES M. LINK, II 



.PAGE 55 ; set maximum page size to 55 lines 

;* * 

; * REGISTER EQUATE TABLE * 

;* * 

;1t*****1t**ic*1c********ieit*it**it*1t1t*1c4c*1c**it ********************* 



; column 


tone 


equates 


CINCR: 


.equ 


rrO 


CINCRH: 


.equ 


rO 


CINCRL: 


.equ 


rl 


CFINCR: 


.equ 


rr2 


CFINCH: 


.equ 


r2 


CFINCL: 


.equ 


r3 


POINT: 


.equ 


rr4 


POINTH: 


.equ 


r4 


POINTL: 


.equ 


r5 


;row tone equates 


RINCR: 


.equ 


rr6 


RINCRH: 


.equ 


r6 


RINCRL: 


.equ 


r7 


RFINCR: 


.equ 


rrS 


RFINCH: 


.equ 


rS 


RFINCL: 


.equ 


r9 


CVAL: 


.equ 


no 


RVAL: 


.equ 


rll 



; current increment in sine table 
;high byte of current increment value 
;low byte of current increment value 
; increment in sine table for frequency 
;high byte of frequency increment value 
;low byte of frequency increment value 
; pointer into sine table 
;high byte of sine table pointer 
;low byte of sine table pointer 

; current increment in sine table 
;high byte of current increment value 
;low byte of current increment value 
/increment in sine table for frequency 
;high byte of frequency increment value 
;low byte of frequency increment value 
/current value to output to DAC-08 
/current row value 



************************************************************ 
;* * 

;* GENERAL EQUATES * 

;* * 

************************************************************ 



/crystal freq in hertz 
/sample frequency in hertz 
; counter load value 
/number of values in sine table 
/desired column frequency 
/desired row frequency 



/note dtmf frequencies are 697,770,852,941,1209,1336,1477,1633 

;*********************************************************** 
J* * 

/* INTERRUPT VECTOR TABLE * 

/* * 

;*********************************************************** 

/this area should always be defined 
/as it reserves the lower 32 bytes 
/for the interrupt table, the name 
/of the subroutine for each particular 
/interrupt service would normally be 
/named here. 



XTAL: 


.equ 


12000000 


SAMPLE: 


.equ 


8000 


CTVAL: 


.equ 


XTAL/4/SAMPLE 


TABSTP: 


.equ 


256 


CFREQ: 


.equ 


1209 


RFREQ: 


.equ 


697 


CFREQI: 


.equ 


(TABSTP*256*C] 


RFREQI : 


.equ 


(TABSTP*256*R] 



INTRO : 


.WORD 


INTRET 


INTRl : 


.WORD 


INTRET 


INTR2 : 


.WORD 


INTRET 


INTR3 : 


.WORD 


INTRET 


INTR4 : 


.WORD 


INTRET 


INTR5: 


.WORD 


INTRET 


INTR6: 


.WORD 


TIMERO 


INTR7 : 


.WORD 


INTRET 


INTR8 : 


.WORD 


INTRET 


INTR9: 


.WORD 


INTRET 


INTRIO: 


.WORD 


INTRET 
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INTRll: .WORD INTRET 

INTR12: .WORD INTRET 

INTR13: .WORD INTRET 

INTR14: .WORD INTRET 

INTRiS: .WORD INTRET 

******************************************************** 

* * 

* START OF PROGRAM EXECUTION * 

* * 
*********************************************************** 



START: jr 



STARTl 



.ASCII 'REL 6/16/86* 



STARTl: di 
sbO 
Id 



Id 
Id 
Id 
Id 



EMT,#OOOOOOOOB 



PO,#OOH 

POM, #111111118 
PM, #001100008 
HlC, #000000006 



program execution unconditionally 

begins at this location after reset 

and power up. 

jump around optional ascii string 

containing release info, copyright, etc. 

begin 

select register bank 

external memory timing=no wait input, normal 

memory timing, no wait states, stack internal, 

and DMA internal 

address begins at OOOOh, set upper byte 

select all lines as address 

enable port as upper 8 bits address 

handshake not enabled port 



port 1 is defined in romless part as address/data, 
here to initialize that port 



it is not necessary 



Id 
Id 
Id 
Id 
Id 
Id 

Id 
Id 
Id 



P2,#00H 

P3,#00H 

P2AM, #101010108 

P2BM, #101010108 

P2CM, #101010108 

P2DM, #101010108 



;port 2 outputs low 
;port 3 outputs low 
;p30, 31,20,21 as output 
;p32,33,22,23 as output 
;p34, 35,24,25 as output 
;p36, 37,26,27 as output 



P4, #100000008 ;set midpoint for DAC inputs 
P4D, #0000.00008 ;set all bits of P4 as output 
P40D, #000000008 ;active push/pull 



basic Super 8 I/O is initialized, now internal registers 

Id RPO,#OCOH ;set working register low to lower 8 bytes 
Id RP1,#0C8H ;set working register high to upper 8 bytes 
Id SPL, #OFFH ;set stack pointer to start at top of set two 
;note here that only lower 8 bits are used 
;for stack pointer, location OFFH is wasted 
;as stack operation. SPH is general purpose 
; storage. 

now clear the internal memory and stack area 

; point to top of general purpose register 
ZERO: clr esPH ;zero it 

;do it until register set is all cleared 
;zero last register 

now everything except working registers is cleared 

cpu and memory now initialized, set up timer for real time clock 



Id 


SPH, # OFFH 


clr 


esPH 


dec 


SPH 


1r 


nz , ZERO 


clr 


§SPH 



Id 
Id 

Id 

sbl 

Id 

Id 

Id 

SbO 
Id 



SYM, #000000008 ; 
IPR, #000000108 ; 

IMR, #000001008 ; 

C0TCH,#^H8(CTVAL) 
COTCL, #^LB(CTVAL) 
COM, #000001008 ; 



COCT, #101001018 



disable fast interrupt response 
interrupt priority 

IRQ2>IRQ3>IRQ4>IRQ5>IRQ6>IRQ7>IRQ0>IRQ1 
enable only interrupt 2 
select bank 1 

;high byte of time constant 

;low byte of time constant 
p27,37 is I/O, programmed up/down, no capture 
timer mode is selected 
select bank 

continuous, count down, load counter, 
zero count interrupt enable, enable counter 



;timer is initialized, now lets enable interrupts and wait 

Idw CINCR,#l /start column at beginning of sine table 
Idw RINCR,#1 ; start row at beginning of sine table 
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;this example loads the tones for digit '1' 

;user software would, of course have to manipulate these registers for 

; proper tone control 

Idw CFINCR, #CFREQI ;load column frequency increment 
RFINCR,#RFREQI 'load row frequency increment 
;pointer points to sine table 
; initial value to prevent glitch at starl 
; enable interrupts 



Idw 


POINT, #SINTAB 


Id 


CVAL, #080H 


ei 




nop 




nop 




nop 




nop 




3r 


WAIT 



;loop back 

;Timer interrupt. Occurs SAMPLE times per second 

; interrupt outputs value to DAC-08 and then determines value for next 

; interrupt. This assures no bit jitter. 

; write new value to DAC-08 

; clear carry flag 

;find next position in sine table 

;by adding' frequency offset to last position 

; set new pointer into sine table 

;get value from sine table 

;find next position in sine table 

;by adding frequencty offset to last position 

;set new pointer into sine table 

;get second value from sine table 

;fdrm a complex /waveform from two sine values 

; reset end of count interrupt 

;ahd return from interirupt 

;* * 

;* SINE WAVE LOOKUP • * 

;* * 

;*********************************************************** 

;sine table for DTMF generation using DAC-08. Table based upon 

;case of waveform consisting of two sine waves summed to provide a single 

; complex waveform with minumum amplititude = volts and maximum 

;amplitittide = 5 volts. DAC-08 input for volts = OOH 

;5 volts = OFFH. Both waves must total no more than OFFH, therefore 

;maximum for one wave must be 1/2 5 volts or 080H. 

;Table generated using following BASICA program, 

;then typed into program. 



TIMERO: 


Id 
rcf 


p4,CVAL 




add 


CINCRL,CFINCL 




adc 


CINCRH,CFINCH 




Id 


POINTL,CINCRH 




Idc 


CVAL, §POINT 




add 


RINCRL,RFINCL 




adc 


RINCRH,RFINqH 




Id 


POINTL,RINCRH 




Idc 


RVAL, ©POINT 




add 


<:VAL,RVAL 




or 


COCT,#00000010B 


INTRET: 


iret 





10 CLS 

20 PI=3. 141593 

30 FOR 1=0 TO 255 

40 C«360/256 

50 D=C*I 

60 E=D*PI/180 

7P F-SIN(E) 

80 G=F*63 

90 H=64+G 

100 J=CINT(H) 

110 A$=HEX$(J) 

120 PRINT A$ 

130 LPRINT A$ 

140 NEJtT 

150 END 



; Clear screen 

; define PI 

;256 total values 

; define basic interval value 

; value from zero on sine wave 

; figure sine for interval from 

;sine range should be from -63 to 63 

;make result from to 127 

; round to nearest integer 

; convert to hex 

;on screen ^ 

;on printer 

;do next inverval 



; *noterremove comments, BASICA will not accept ; as comment delimiter 



SINTAB:, .ORG 0400H ;begin sine table on even byte boundary 

.byte 040H, 042H, 043H, 045H, 046H, 048H, 049H, 04BH, 04CH, 04EH, 04FH, 051H 

. byte 052H, 054H, 055H, 057H, 058H, 05AH, 05BH, 05CH, 05EH, 05FH, 060H, 062H 

.byte 063H, 064H, 066H, 067H, 068H, 069H, 06AH, 06BH, 06DH, 06EH, 06FH, 070H 

.byte 071H, 072H, 073H, 074H, 074H,075H, 076H, 077H, 078H, 078H, 079H, 07AH 

.byte 07AH, 07BH, 07BH, 07CH, 07CH, 07DH, 07DH, 07DH, 07EH, 07EH, 07EH, 07FH 

.byte 07FH, 07FH, 07FH, 07FH, 07FH, 07FH, 07FH, 07FH, 07FH, 07FH, 07EH, 07EH 

.byte 07EH, 07DH, 07DH, 07DH, 07CH, 07CH, 07BH, 07BH, 07AH, 07AH, 079H, 078H 

.byte 078H, 077H, 076H, 075H, 074H, 074H, 073H, 072H, 071H, 070H, 06FH, 06EH 

. byte 06DH, 06BH, 06AH, 069H, 068H, 067H, 066H, 064H, 063H, 062H, 060H, 05FH 

.byte 05EH, 05CH, 05BH, 05AH, 058H, 057H, 055H, 054H, 052H, 051H, 04FH, 04EH 

.byte 04CH, 04BH, 049H, 048H, 046H, 045H, 043H, 042H, 040H, 03EH, 03DH, 03BH 

.byte 03AH, 038H, 037H, 035H, 034H, 032H, 031H, 02FH, 02EH, 02CH, 02BH, 029H 

.byte 028H,026H,025H,024H,022H,021H,020H,01EH,01DH,01CH,01AH,019H 

.byte 018H, 017H, 016H, 015H, 0X3H, 012H, OllH, OlOH, OOFH, OOEH, OODH, OOCH 

.byte OOCH, OOBH, OOAH, 009H, 008H, 008H, 007H, 006H, 006H, 005H, 005H, 004H 

. byte 004H, 003H, 003H, 003H, 002H, 002H, 002H, OOIH, OOIH, OOIH, OOIH, OOIH 

.byte OOIH, OOIH, OOIH, OOIH, OOIH, OOIH, 002H,002H,002H,003H,003H,003H 

.byte 004H, 004H, 005H, 005H, 006H, 006H, 007H, 008H, 008H, 009H, OOAH, OOBH 

.byte OOCH, OOCH, OODH, OOEH, OOFH, OlOH, OllH, 012H, 013H, 015H, 016H, 017H 

.byte 018H,019H,01AH,01CH,01DH,01EH,020H,021H,022H,024H,025H,026H 

.byte 028H, 029H, 02BH, 02CH, 02EH, 02FH, 031H, 032H, 034H, 035H, 037H, 038H 

.byte 03AH,03BH,03DH,03EH 
.END 



494 



<5iZiK5G 



Application Note 



August 1987 



A SIMPLE SERIAL TO 
PARALLEL CONVERTER 
USING THE ZILOG SUPERS 

by Charles M. Link, II 



The Zilog Supers has many on-board peripherals that 
provide multiple user applications. Earlier articles have 
demonstrated simple application "stubs" or short test 
programs. This article and the next article demonstrate a 
useful application for the Supers. Although it 
underutillzes the SuperS's power, the simple serial to 
parallel converter in this application and the print buffer in 
the next application demonstrate the ease at which 
applications are developed with the Supers. 

The Zilog Supers has several features that enhance its 
use as a communication controller. The interrupt or DMA 
driven serial port are helpful, but the handshaking 
parallel ports finish the job. In the serial to parallel 
converter, the 256 byte internal register memory is used 
as a small circular queue. 



Hardware for this application is fairly simple. Port 4 is 
buffered and hooked to the data lines, as shown, to 
interface to a Centronics type printer connector. The 
strobe from P25 provides the strobe (pin 1 ) to the printer. 
The acknowledge line from the printer is inverted and 
tied to P24 of the SuperS. The busy signal from the 
printer is buffered and tied to P23 of the Supers. The 
design was tested on an Okidata printer and is not 
guaranteed to work on all printers. 

Software is fairly straightforward. The serial port is 
initialized just like it was in the application article on the 
interrupt driven serial port. Port 4 must be set-up as 
outputs with active push-pull drivers. Port 2, bits 3 and 4, 
are set up as input with P24 set to enable interrupts. P25 
is set as output and handshake is set In HOC to provide 
a strobe of 1 6 clock periods in length. 



.TITLE Sample Zilog Super 8 Serial to Parallel Converter 



TITLE: 

DATE: 

PURPOSE: 



ASSEMBLER: 
PROGRAMMER: 



SERPAR.S 

JULY 17, 1986 

TO DEMONSTRATE INTERRUPT 

DRIVEN SERIAL PORT IN A 

REALISTIC APPLICATION. 

THIS APPLICATION RECEIVES 

SIMPLE SERIAL DATA A SENDS IT 

OUT THE PARALLEL PORT TO A 

PRINTER. 

ZILOG ASMS8 ASSEMBLER 

CHARLES M. LINK, II 



.PAGE 55 ;set maximum page size to 55 lines 

jitit ************* itieltit it************************ *****-kieic*ie**1tit* 
;* * 

;* GENERAL EQUATES * 

;* * 

J*********************************************************** 



CR: 
LF: 



. equ OdH 
.equ OaH 



; carriage return 
;line feed 



*********************************************************** 

* ' * 

* REGISTER EQUATE TABLE * 

*********************************************************** 
working register equates 



INPNT: .equ R3 
OUTPNT: .equ R4 



; input character pointer 
; output character pointer 



495 



MPTR: ' 


.equ 


RR6 


ACKB: 


.equ 


R5 


ACKBIT: 


.equ 






message pointer for external memory 
;byte containing acknowledge bit 
;bit set = no acknowledge yet 
;bit clear = not waiting on acknowledge 

;* * 

;* INTERRUPT VECTOR TABLE * 

;* * 
**************************************************** 

;this area should always be defined 
;as it reserves the lower 32 bytes 
; for the interrupt table . the name 
;of the subroutine for each particular 
/interrupt service would normally be 
; named here. 



/receive data interrupt 



INTRO: 


.WORD 


INTRET 


INTRl: 


.WORD 


INTRET 


INTR2 : 


.WORD 


INTRET 


INTR3 : 


.WORD 


INTRET 


INTR4 : 


.WORD 


INTRET 


INTR5 : 


.WORD 


INTRET 


INTR6: 


.WORD 


INTRET 


INTR7: 


.WORD 


INTRET 


INTR8 : 


.WORD 


INTRET 


INTR9 : 


.WORD 


INTRET 


INTRIO: 


.WORD 


RXDATI 


INTRl 1: 


.WORD 


INTRET 


INTRl 2 : 


.WORD 


INTRET 


INTRl 3 : 


.WORD 


INTRET 


INTR14 : 


.WORD 


ACKSTB 


INTR15: 


.WORD 


INTRET 



/acknowledge strobe interrupt 



J *1c**ic'kic-k****1ck*1fk*********'k1c1i***it *********** *************** 
J* * 

;* START OF PROGRAM EXECUTION ' * 

;* * 

************************************************************ 



START: jr 



STARTl 



.ASCII 'REL 7/17/86' 



STARTl: di 
sbO 
Id 



EMT,#O000000OB 



Id PO,#OOH 

Id P0M,#11111111B 

Id PM,#00110000B 

Id HlC, #000000008 



program execution unconditionally 

begins at this location after reset 

and power up. 

jump around optional ascii string 

containing release info, copyright, etc. 

begin 

select register bank 

external memory timing=no wait input, normal 

memory timing, no wait states, stack internal, 

and DMA internal 

address begins at OOOOh, set upper byte 

select all lines as address 

enaible port as upper 8 bits address 

handshake not enabled port 



(port 1 is defined in romless part as address/data, it is not necessary 
here to initialize that port 



Id 
Id 
Id 



Id 
Id 
Id 

Id 
Id 
Id 
Id 



P2, #001000008 

P3,#00H 

P2AM, #100010108 



P28M, #101000108 
P2CM, #101010018 
P2DM, #101010108 



/port 2 outputs low, except strobe bit 

/port 3 outputs low 

/p31,20,21 as output, p30 input 

/it is necessary here to configure p30 as input 

/for the receive data, and p31 as output for 

/transmit data for UART 

/p32,33,22 as output, 23 as input 

/p34,35,25 as output, 24 as input, interrupt en 

/p36, 37, 26,27 as output 



P4, #000000008 /clear port 4 register 

P4D, #000000008 /set all bits of P4 as outputs 

P4OD,#00000000B /active push/pull 

HOC, #111100018 /handshake enable for port 4, 16 clock pulse 



basic Super 8 I/O is initialized, now internal registers 

Id RPO,#OCOH /set working register low to lower 8 bytes 
Id RP1,#0C8H /set working register high to upper 8 bytes 
Id SPL,#OFFH /set stack pointer to start at top of set two 
/ note here that only lower 8 bits are used 
/for stack pointer, location OFFH is wasted 
/as stack operation. SPH is general purpose 
/ storage . 

/now clear the internal memory and stack area 
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; point to top of general purpose register 
ZERO: clr @SPH ;zero it 

;do it until register set is all cleared 
;zero last register 

now everything except working registers is cleared 

cpu and memory now initialized, set up timer for real time clock 



Id 


SPH,#OFFH 


clr 


espH 


dec 


SPH 


ir 


nz , ZERO 


clr 


espH 



Id 
Id 



Id 



SYM,#OOOOOOOOB /disable fast interrupt response 
IPR,#10111111B ; interrupt priority 

;IRQ6>IRQ7>IRQ5>IRQ4>IRQ3>IRQ2>IRQ1>IRQ0 
IMR, #010100008 ;rx interrupts, acknowledge strobe 



timer is set, now lets initialize the UART for polled operation 



sbl 
Id 



Id 
Id 
Id 



UMA, #011100006 



UBGH,#^HB(00009) 
UBGL,#^LB(00009) 
UMB, #000111106 





sbO 






Id 


UTC, #100010006 




Id 


UIE, #000000016 




Id 


URC, #000000106 


;UART 


is initialized, reset ackn* 




bitr 


ACK8, #ACK6IT 




Id 


P26IP, #000000016 




ei 




WAIT: 


Idw 


MPTR, #MSG 




call 


SENDM 




Id 


INPNT,#0 




Id 


OUTPNT,#0 


WAITl: 


call 


SND6UF 


; 


jr 


WAITl 


SENDM: 


tm 


P2, #000010006 




jr 


nz , SENDM 




btjrt 


SENDM, ACK6,#ACK6] 




bits 


ACK6,#ACK6IT 




Idci 


rO,eMPTR 




Id 


P4 , rO 




nop 






nop 






nop 






cp 


rO,#»$' 




jr 


ne, SENDM 


, 


ret 




; 

SNDBUF 


: cp 


INPNT,OUTPNT 




jr 


ne,SCl 




ret 




SCl: 


tm 


P2, #000010006 




jr 


nz,SCl 1 




btjrt 


SC1,ACK6,#ACK6IT 

1 




di 






bits 


ACK6,#ACK6IT 




Id 


P4,§0UTPNT ; 




tm 


P2, #000000016 



;bank 1 

;time constant = (12,000,000/4/16/9600/2)-!= 
;8.76 rounded to 9. 

;note that a 12 Mhz does not make a very 
; accurate baud rate source, error is large 

;high byte of time constant 

;low byte of time constant 
rp21-p21data, auto-echo is off, transmit and 
; receive clock is baud rate generator output, 
ibaud rate generator input is system clock / 2, 
;baud rate generator is enabled, loopback 
ris disabled 
r select bank 

r select p31 as transmit data out, 1 stop bit 
land transmit enable 
r receive interrupts, no DMA 
r enable receiver 



; reset acknowldege bit if set 

; reset interrupt input flip-flop 
; enable interrupts 
; point to message 
;send the message 
;set input pointer to register 
;set output pointer to register 
;send any characters in buffer 
;loop back 



; printer busy 

;wait for printer unbusy 

IT ;see if the acknowledge has occurred 

;from possible last byte 
;set acknowledge bit before writing to output 
;get the character 
;send to printer 
; allow 18 clocks for strobe 



;last character? 
loop back for next 



compare inpointer to outpointer 
send character if any to send 

/otherwise return 
printer busy? 

;if so, wait until it is not busy 

;see if acknowledge has occurred 

;from possible last byte 



;set acknowledge bit before writing to output 
;send the character 
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HON: 



1r 


z,HON 


Id 


rO , OUTPNT 


xor 


iro, #100000005 


cp 


INPNT,rO 


jr 


ne,HON 


and 


P2, #111111103 


nop 




inc 


OUTPNT 


ei 




ret 





;if host is on 

;get the output pointer 

;add 128 to it 

;turn host back on when 128 bytes left in buf 

; otherwise keep sending 

;host back on 

;bump pointer 

;to make sure pointer not changed 



;send character in rO 

SENDC: tm UTC, #000000108 ;transmit buffer empty yet 
jr z, SENDC ;if not, wait until it is 
Id UIO,rO ;load the character into the transmitter 
ret 
; receive character available interrupt / 

;get input from console 
; remove upper parity bit 
;echo to console 
;save th^ character 
;bump input pointer 
;has the input made a complete loop? 

receive character buffer full, stop sending device 

or P2, #000000016 ;raise DTR to stop host sending 
INTRET: 
RXIT^: iret 



RXDATI: Id 


rO,UIO 


and 


rO,#7fH 


call 


SENDC 


Id 


@INPNT,rO 


inc 


INPNT 


cp 


INPNT, OUTPNT 


jr 


ne,RXIT 



ACKSTB: 



ACKSl; 



MSG: 



tm 
bitr 



P2,#00010000B 
ACKB,#ACKBIT 



;is line low or high now 

; reset acknowledge bit in register 



tm P2,#00010000B ;test ack bit 

jr z, ACKSl ;wait here till end of strobe 

Id P2BIP,#00000001B ;reset p24 interrupt pending register 

iret ;and return 

.ASCII CR,LF, 'Super8 serial/parallel test program. • ,CR, LP 

.ASCII 'Second line test data* ,CR,LF, '$• 



.END 



.TITLE Sample Zilog Super 8 Serial to Parallel Converter with XON/XOFF 



TITLE: 

DATE: 

PURPOSE: 



ASSEMBLER: 
PROGRAMMER: 



SERPARl.S 
JULY 17, 1986 
TO DEMONSTRATE INTERRUPT 
DRIVEN SERIAL PORT IN A 
REALISTIC APPLICATION. 
THIS APPLICATION RECEIVES 
SIMPLE SERIAL DATA A SENDS IT 
OUT THE PARALLEL PORT TO A 
PRINTER. FLOW CONTROL IS BY 
XON/XOFF COMMANDS ON THE BACK 
CHANNEL TO THE HOST 
ZILOG ASMS 8 ASSEMBLER 
CHARLES M. LINK, II 



.PAGE 55 ;set maximum page size to 55 lines 

* * 

* GENERAL EQUATES * 

* * 

**1c*1c*1eic-l(* ************** 1i**ie-k******************1c***ie**-k*1t*'k 



CR: 
LF: 



.equ 
.equ 



OdH 
OaH 



; carriage return 
;line feed 
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• 


.equ 


IIH 


;control-Q of DCl 


F: 


• equ 


13H 


;control-S or DC3 



;* * 

;* REGISTER EQUATE TABLE * 

• * * 

r 

/working register ec[uates 

INPNT: .equ R3 ; input character pointer 

OUTPNT: .equ R4 ; output character pointer 

MPTR: .equ RR6 /message pointer for external memory 

ACKB: .equ R5 ;byte containing acknowledge bit 

ACKBIT: .equ ;bit set = no acknowledge yet 

;bit clear = not waiting on acknowledge 

XBIT: .equ 1 ;XOFF send to host 
J 

;* * 

;* INTERRUPT VECTOR TABLE * 



INTRO! 


• WORD 


INTRET 


INTRl: 


.WORD 


INTRET 


INTR2 : 


.WORD 


INTRET 


INTR3: 


.WORD 


INTRET 


INTR4! 


.WORD 


INTRET 


INTR5: 


.WORD 


INTRET 


INTR6: 


.WORD 


INTRET 


INTR7 : 


.WORD 


INTRET 


INTR8: 


.WORD 


INTRET 


INTR9! 


.WORD 


INTRET 


INTRl 0: 


.WORD 


RXDATI 


INTRl 1: 


.WORD 


INTRET 


INTR12 : 


.WORD 


INTRET 


INTRl 3: 


.WORD 


INTRET 


INTR14! 


.WORD 


ACKSTB 


INTR15 : 


.WORD 


INTRET 



;this area should always be defined 
;as it reserves the lower 32 bytes 
;for the interrupt table, the name 
;of the subroutine for each particular 
/interrupt service would normally be 
/named here. 



•receive data interrupt 



/acknowledge strobe Interrupt 



/* * 

/* START OF PROGRAM EXECUTION * 

;* * 

************************************************************ 



START: di /for emulation if nothing else 

/program execution unconditionally 
/begins at this location after reset 
/and power up. 

/jump around optional ascii string 
/containing release info, copyright, etc. 

STARTl: sbo /select register bank 

/external memory timing«no wait input, normal 

/memory timing, no wait states, stack internal, 

/and DMA internal 

^address begins at OOOOh, set upper byte 

/select all lines as address 

/enable port as upper 8 bits address 

/handshake not enabled port 

port 1 is defined in romless part as address/data, it is not necessary 
here to initialize that port 



di 

jr 


STARTl 


.ASCII 


•REL 7/17/86 • 


sbO 
Id 


EMT, #000000006 


Id 
Id 
Id 
Id 


PO,#OOH 
POM, #111111116 
PM, #001100006 
HlC, #000000006 



Id 

Id 
Id 



Id 
Id 
Id 

Id 
Id 



P2, #001000006 /port 2 outputs loW, except strobe bit 

P3,#00H /port 3 outputs low 

P2AM, #100010106 /p31,20,21 as output, p30 input 

/it is necessary here to configure p30 as input 
/for the receive data, and p31 as output for 
/transmit data fot UART 

P26M, #101000108 /p32,33,22 as output, 23 as input 

P2CM, #101010016 /p34,35,25 as output, 24 as input, interrupt en 

P2DM, #101010108 /p36,37,26,27 as output 

P4, #000000008 /clear port 4 register 

P4D, #000000008 /set all bits of P4 as outputs 
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Id 
Id 



P40D, #000000008 jactive push/pull 

HOC, #111100018 ;handshake enable for port 4, 16 clock pulse 



basic Super 8 I/O is initialized, now internal registers 

Id RP0,#0C0H ;set working register low to lower 8 bytes 
Id RP1,#0C8H ;set working register high to upper 8 bytes 
Id SPL,#OFFH ;set stack pointer to start at top of set two 
;note here that only lower 8 bits are used 
;for stack pointer, location OFFH is wasted 
;as stack operation. SPH is general purpose 
? storage . 

now clear the internal memory and stack area 

; point to top of general purpose register 
ZERO: clr @SPH ;zero it 

;do it until register set is all cleared 
;zero last register 

now everything except working registers is cleared 

cpu and memory now initialized, set up timer for real time clock 



Id 


SPH,#OFFH 


clr 


@SPH 


dec 


SPH 


jr 


nz , ZERO 


clr 


esPH 



Id 
Id 



Id 



SYM, #000000008 ;disable fast interrupt response 
IPR, #101111118 /interrupt priority 

;IRQ6>IRQ7>IRQ5>IRQ4>IRQ3>IRQ2>IRQ1>IRQ0 
IMR, #010100008 ;rx interrupts, acknowledge strobe 



timer is set, now lets initialize the UART for polled operation 



sbl 
Id 



Id 
Id 
Id 



sbO 
Id 



Id 
Id 



UMA, #011100008 



U8GH,#^HB(00009) 
UBGL,#^IiB( 00009) 
UM8, #000111108 



UTC, #100010008 

UIE, #000000018 
URC, #000000108 



;bank 1 

;tiroe constant - (12,000,000/4/16/9600/2) -1= 
;8.76 rounded to 9. 

;note that a 12 Mhz does not make a very 
/accurate baud rate source, error is large 

;high byte of time constant 

;low byte of time constant 
; p21=p2 Ida ta, auto-echo is off, transmit and 
/receive clock is baud rate generator output, 
;baud rate generator input is system clock / 2, 
/baud rate generator is enabled, loopback 
/is disabled 
/select bank 

/select p31 as transmit data out, 1 stop bit 
/and transmit enable 
/receive interrupts, no DMA 
/enable receiver 



UART is initialized, reset acknowledge bit and begin 



WAIT: 



WAITl: 



SENDM: 



bitr 

bitr 

Id 

ei 

Idw 

call 

Id 

Id 

call 

jr 



tm 
jr 
btjrt 

bits 

Idci 

Id 

nop 

nop 

nop 

cp 

jr 

ret 



ACK8,#ACK8IT /reset acknowldege bit if set 

ACKB,#XBIT /reset XON/XOFF bit 

P28IP, #000000018 /reset interrupt input flip-flop 

/enable interrupts 
MPTR,#MSG /point to message 
SENDM /send the message 

INPNT,#0 /set input pointer to register 
OUTPNT,#0 /set output pointer to register 
SNDBUF /send any characters in buffer 
WAITl /loop back 



P2, #000010008 /printer busy 
nz, SENDM /wait for printer unbusy 

SENDM, ACKB,#ACK8IT /see if the acknowledge has occurred 
/from possible last byte 

/set acknowledge bit before writing to output 

/get the character 

/send to printer 

/allow 18 clocks for strobe 



ACK8,#ACKBIT 

r0,§MPTR 

P4,r0 



r0,#'$' 
ne, SENDM 



/last character? 
/loop back for next 
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; tinier is initialized, now lets enable interrupts and wait 

Idw CINCR,#1 /start column at beginning of sine table 
Idw RINCR,#1 ; start row at beginning of sine table 

this example loads the tones for digit '1' 

user software would, of course have to manipulate these registers for 

proper tone control 



WAIT: 



Idw 

Idw 

Idw 

Id 

ei 

nop 

nop 

nop 

nop 

jr 



CFINCR, #CFREQI 
RFINCR,#RFREQI 
POINT, #SINTAB 
CVAL,#080H 



WAIT 



;load column frequency increment 

;load row frequency increment 

; pointer points to sine table 

/initial value to prevent glitch at start 

/enable interrupts 



;loop back 



Timer interrupt. Occurs SAMPLE times per second 

interrupt outputs value to DAC-08 and then determines value for next 

interrupt. This assures no bit jitter. 

TIMERO: Id p4,CVAL /write new value to DAC-08 

rcf /clear carry flag 

add CINCRL,CFINCL /find next position in sine table 

adc CINCRH,CFINCH /by adding frecjuency offset to last position 

Id POINTL,CINCRH /set new pointer into sine table 

Idc CVAL, ©POINT /get value from sine table 

add RINCRL,RFINCL /find next position in sine table 

adc RINCRH,RFINCH /by adding frequencty offset to last position 

Id POINTL,RINCRH /set new pointer into sine table 

Idc RVAL, ©POINT /get second value from sine table 

add CVAL,RVAL /form a complex waveform from two sine values 

or C0CT,#00000010B /reset end of count interrupt 

INTRET; iret /and return from interrupt 

*********************************************************** 

* * 

* SINE WAVE LOOKUP * 

* * 
*********************************************************** 

sine table for DTMF generation using DAC-08. Table based upon 

case of waveform consisting of two sine waves summed to provide a single 

complex waveform with minumuro amplititude = volts and maximum 

amplititude = 5 volts. DAC-08 input for volts = OOH 

5 volts = OFFH. Both waves must total no more than OFFH, therefore 

maximum for one wave must be 1/2 5 volts or 08 OH. 

Table generated using following BASICA program, 

then typed into program. 



10 CLS 

20 PI=3. 141593 

30 FOR 1=0 TO 255 

40 C«360/256 

50 D=C*I 

60 E=D*PI/180 

70 F«SIN(E) 

80 G=F*63 

90 H=64+G 

100 J=CINT(H) 

110 A$=HEX$(J) 

120 PRINT A$ 

130 LPRINT A$ 

140 NEXT 

150 END 



/clear screen 

/define PI 

/256 total values 

/define basic interval value 

/value from zero on sine wave 

/figure sine for interval from 

/sine range should be from -63 to 63 

/make result from to 127 

/round to nearest integer 

/convert to hex 

/on screen 

/on printer 

/do next inverval 



♦note-remove comments, BASICA will not accept / as comment delimiter 

SINTAB: .ORG 0400H /begin sine table on even byte boundary 

.byte 040H, 042H, 043H, 045H, 046H, 048H, 049H, 04BH, 04CH, 04EH, 04FH, 051H 

.byte 052H, 054H, 055H, 057H, 058H, 05AH, 05BH, 05CH, 05EH, 05FH, 060H, 062H 

.byte 063H, 064H, 066H, 067H, 068H, 069H, 06AH, 06BH, 06DH, 06EH, 06FH, 070H 

.byte 071H, 072H, 073H, 074H, 074H, 075H, 076H, 077H, 078H, 078H, 079H, 07AH 

.byte 07AH, 07BH, 07BH, 07CH, 07CH, 07DH, 07DH, 07DH, 07EH, 07EH, 07EH, 07FH 
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SNDBUF: 



SCI: 



HON: 



cp 


INPNT,OUTPNT 


jr 


ne,SCl 


ret 




tm^ 


P2,#00001000B 


jr 


nz,SCl 


btjrt 


SC1,ACKB,#ACKB 


di 




bits 


ACKB,#ACKBIT 


Id 


P4 , §OUTPNT 


btjrf 


HON,ACKB,#XBIT 


Id 


rO,OUTPNT 


xor 


rO,#10000000B 


cp 


INPNT,rO 


jr 


ne,HON 


Id 


rO,XON 


call 


SENDC 


bitr 


ACKB,#XBIT 


nop 




inc 


OUTPNT 


ei 




ret 





; compare inpolnter to outpointer 
;send character if any to send 
; otherwise return 
; printer busy? 

;if so, wait until it is not busy 
I? ;see if acknowledge has occurred 
;from possible last byte 



;set acknowledge bit before writing to output 

;send the Character 

;host is still sending 

;get the output pointer 

;add 128 to it 

;turn host back on when 128 bytes left in buf 

; otherwise keep sending 

;send XON to host to start it sending again 

; reset XOFF bit 

;buinp pointer 

?to make sure pointer not changed 



;send character in rO 

SENDC: tm UTC,#00000010B ;transmit buffer empty yet 

jr z, SENDC ;if not, wait until it is 

Id UIO,rO ;load the character ihto the transmitter 

ret 
; receive character available interrupt i 

RXDATI: Id rO,UIO ?get input from console 

and rO,#7fH ; remove upper parity bit 

call SENDC ;echo to console 

Id §INPNT,rO ;saye the character 

inc INPNT ;bump input pointer 

Id rO, INPNT ;get the input pointer 

add r0,#5 ;ailow 5 characters after XOFF 

cp rO, OUTPNT ;has the input made a complete loop? 

jr ne,RXIT 

receive character buffer full, stop sending device 



INTRET: 
RXIT: 



Id 

call 

bits 

iret 



rO,#XOFF 

SENDC 

ACKB,#XBIT 



;send XOFF to host 

;send it 

;set the XOFF bit 



ACKSTB: 



ACKSl: 



; 
MSG: 



tm 
bitr 

tm 
jr 
Id 
iret 

.ASCII 
.ASCII 

.END 



P2,#00010000B 
ACKB,#ACKBIT 

P2,#00010000B 
z, ACKSl 
P2BIP,#00000001B 



;is line low or high now 

; reset acknowledge bit in register 

;test ack bit 
;wait here till end of strobe 

; reset p24 interrupt pending register 
and return 



CR,LF, »Super8 serial/parallel test program. » ,CR,LF 
•Second line test data» ,CR,LF, '$• 
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Chapter 1 
Supers Overview 



1.1 INTRODUCTION 



1.3 BASIC HICROCONPUTERS 



The Supers family consists of basic microcom- 
puters, protopack emulators, and ROMless microcom- 
puters. The various family members differ in the 
amount of on-chip ROM and the physical packaging. 

All of the Supers family members offer a full- 
duplex universal asynchronous receiver/transmitter 
(UART) with an on-chip baud-rate generator, two 
16-bit programmable counter/timers, a direct 
memory access (DMA) controller, and an on-chip 
oscillator. 



1.2 FEATURES 

Supers microprocessor features include: 

• 325 byte-wide registers, including 272 general- 
purpose registers and 53 mode and control 
registers 

• Full-duplex UART with special features 

• Up to 32 bit-programmable and 8 byte- 
programmable I/O lines, with 2 handshake chan- 
nels 



These parts are the core of the SuperS family of 
products. They have various amounts of mask- 
programmable on-chip ROM, are suitable for high 
volume applications, and require a single +5 Vdc 
power supply. 



1.4 PROTOPACK MICROCOMPUTERS 

These parts function as emulators for the basic 
microcomputer versions. They use the same package 
and pin-out as the basic microcomputer but also 
have a 28-pin "piggy back" socket on the top into 
which a ROM or EPROM can be installed, to replace 
the on-chip ROM of the basic microcomputer. 

This package permits the protopack to be used in 
prototype and final PC boards while still permit- 
ting user program development. When a final 
program is developed, it can be mask-programmed 
into the production microcomputer device, directly 
replacing the emulator. The protopack parts are 
also useful in situations where the cost of mask- 
programming is prohibitive or where program flex- 
ibility is desired. 



• Addressing of up to 12SK byes of memory. 

• An interrupt structure that supports: 

• 27 interrupt sources 

• 16 interrupt vectors (2 reserved for future 
versions) 

• 8 interrupt levels 

• Servicing in 6 CPU clock cycles 

• Two Register Pointers that allow use of short 
and fast instructions to access register groups 
within 600 ns. 

• An instruction set that includes multiply and 
divide instructions. Boolean and BCD operations 

• Additional instructions that support threaded- 
code languages, such as Forth 



1.3 ROMLESS MICROCOMPUTERS 

The ROMless microcomputers are similar to the 
basic microcomputer parts, but have no internal 
ROM. Port 1 is dedicated as an 8-bit address/data 
bus and PO0-PO4 are dedicated address lines. Up to 
64K bytes of external memory can be addressed by 
configuring Port as address bits. The address 
capability can be doubled to 128K bytes by 
programming P35 of Port 3 as the Data Memory 
select signal HR. The two states of this signal 
can be used with the 16-bit address bus to address 
two separate banks of external memory, each with 
up to 64K bytes. 
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Chapter 2 
Architectural Overview 



2.1 INTRODUCTION 

The Supers is a versatile single-chip micro- 
computer that can be programmed for many different 
memory and I/O configurations. This flexibility 
has been achieved by merging a multiplexed 
address/data bus with several l/0-oriented ports. 
This provides the user with large amounts of 
external memory while maintaining many I/O lines. 
Figure 2-1 shows the SuperB block diagram. 



2.2 ADDRESS SPACES 

To provide for both I/O and memory intensive 
applications, the SuperB supports three basic 
address spaces; 



• Program memory (internal and external) 

• Data memory (external) 

• Register file (internal) 

A maximum of 64K bytes of program memory is 
directly addressable. When present, internal 
program memory normally consists of mask- 
programmed ROM. The data memory space is 64K 
bytes in size. 

The ease of interfacing with external memory is 
enhanced with options for programmable wait states 
and half-speed memory timing, as well as an 
optional external wait input. 
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Figure 2-1 . Functional Blocic Diagram 
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Architectural Overview 



2.3 REGISTER FILE 



2.4.1 Addressing Nodes 



The SuperB architecture centers around an internal 
register file composed of 325 registers. All 
registers are eight bits wide, ' Of the 272 
general-purpose registers, 208 can be used as ah 
accumulator, address pointer, index register, data 
register, or stack register. The 64 remaining 
general- pur pose registers are limited to Indirect 
or Indexed addressing mode functions such as 
stacks, data buffers, and look-up tables. Fifty- 
three registers are dedicated to special control 
and status operations. 



2.3.1 Register Pointer 

The register file is logically divided into 32 
working register groups of 8 registers each when 
using 4-bit register addressing. Two groups may 
be active at any one time and the two Register 
Pointers (RPO and RP1 ) contain the base addresses 
of these two working register groups. This allows 
fast context switching and shorter instruction 
formats. 



2.3.2 Instruction Pointer 

The Super8 hardware includes features that facili- 
tate the implementation of threaded-code languages 
such as Forth. These include a special 16-bit 
register called the Instruction Pointer (IP) and 
three special CPU instructions called NEXT, ENTER, 
and EXIT. The IP can also be us6d to support the 
fast interrupt prpcessing mode. 



2.4 INSTRUCTION SET 

The CPU has an instruction set designed for its 
large register file. This includes a full comple- 
ment of 8-bit arithmetic and logical operations, 
including multiply and divide. Binary-Coded 
Decimal (BCD) operations are supported using a 
decimal adjustment of binary values. Incrementing 
and decrementing 16-bit quantities for addresses 
and counters are also supported. Extensive bit 
manipulation, including Rotate and Shift instruc- 
tions, round out the data manipulation capabili- 
ties of the Supers. No special I/O instructions 
are necessary since I/O is mapped into the regis- 
ter file. 



The addressing modes of the SuperB Central 
Processing Unit (CPU) are: 

• Register (R) 

• Indirect Register (IR) 

• Indirect Address (lA) 

• Immediate (IM) 

• Direct Address (DA) 

• Indexed (X) 

• Relative Address (RA) 

Register, Indirect Register, and Immediate 
addressing modes are available for Load, Arith- 
metic, Logical, Shift, Rotate, and Stack instruc- 
tions.. Conditional jumps support both the Direct 
and Relative addressing modes, while Jump and Call 
instructions support the Direct, Indirect, and 
Indirect Register addressing modes. Only Load 
instructions support Indexed addressing. 



2.4.2 Data Types 

The SuperB CPU supports operations on bits, bytes, 
BCD digits, and 2-byte words. 

Bits in the register file can be set, cleared, 
complemented, and tested. Bits within a byte are 
numbered from to 7; bit is the least signifi- 
cant (right-most) bit. 

Bytes in the register file can be operated on by 
Arithmetic, Logical, Shift and Rotate, and Load 
instructions. Bytes in memory can be operated on 
only by load or stack instructions. 

Manipulation of BCD digits, packed two to a byte, 
is accomplished by a Decimal Adjust instruction 
and a Swap instruction. Decimal Adjust is used 
after either a binary addition or subtraction on 
BCD digits. 

Words in the register file can be loaded, incre- 
mented, and decremented with the 16-bit Load Word, 
Increment Word, and Decrement Word instructions. 
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2.5 I/O OPERATIONS 



2* 5.2 On-Chip Peripherals 



The Supers has I/O lines grouped into five ports 
of eight lines each. Ports are configurable as 
input, output, or bidirectional. Under software 
control, the ports can provide timing, status 
signals, address outputs, and I/O ports with or 
without handshaking. Multiprocessor system 
configurations are also supported. 



To help cope with real-time problems such as 
counting/timing, the SuperS contains two counter/ 
timers with a large number of user selectable 
modes. It also contains an on-chip universal 
asynchronous receiver/transmitter (UART) which has 
its own built-in baud-rate generator that can be 
used as a counter when not being used to generate 
baud rates. 



2.5.1 Interrupts 

I/O operations can be ihterrupt-driven or polled. 
The Supers supports 16 vectored interrupts on 
eight different levels from 27 interrupt sources. 
Each level can be masked and prioritized. 
Optional high-speed interrupt processing can be 
used on any one of the levels for minimum latency. 



A DMA channel is provided that allows high-speed 
data transfers between on-chip peripherals and the 
register file or external memory. 



2.6 OSCILLATOR 

In addition to these features, the SuperS offers 
an on-chip oscillator requiring only an external 
crystal for operation. ' 
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Chapter 3 
Address Spaces 



3.1 INTRODtlCTION 

The Supers microprocessor supports the following 
address spaces: 

• CPU register file 

• Program memory 

• Data memory 



3.2 CPU REGISTER FILE 

Registers within the Supers CPU's internal regis- 
ter file are identified with an 8-bit acjdress, 
yielding 256 possible register addresses. However, 
the upper 64 addresses are used more than once, as 
described below. A total of 325 registers is 
available, including 272 general-purpose registers 
and 53 special control and status registers. Two 
of these registers are Register Pointers. 



A total of 325 registers is accessible with 192 
registers (OO^-BFh) accessible in all address- 
ing modes. These can be used as accumulators, 
working registers, data buffers, internal stack, 
and so forth. It is possible to set up a 256-byte 
data buffer and still have 16 registers remaining 
as accumulators and working registers. 

Figures 3-1 and 3-2 show layouts of the register 
file address space. The upper 64 bytes of the 
address space (COj^-FF^) contain two sets of 
registers. The first set can be accessed only by 
the Register addressing mode; the second set can 
be accessed by the Indirect Register and Indexed 
addressing modes, stack operations, and DMA 
accesses. The registers in the second set are 
usable as data buffers or as an internal stack 



EOh 
DFh 



DOh 
CFh 



COh 



MODE AND ^ 

CONTROL REGISTERS 
(REGISTER ADDRESSING ONLY) 



SYSTEM REGISTERS: 

STACK, FLAGS, PORTS, ETC. 

(REGISTER ADDRESSING ONLY) 



WORKING REGISTERS 
(WORKING REGISTER 
ADDRESSING ONLY) 



- BANK1 
- BANKO 



DATA REGISTERS 

(INDIRECT REGISTER, INDEXED, 

STACK OR DMA 

ACCESS ONLY) 



^ 



DATA REGISTERS 
(ALL ADDRESSING MODES) 



*> 



Figure 3-1 . Supers Registers 
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SPECIAL PURPOSE 
ADORESS REGISTERS 



GENERAL PURPOSE REGISTERS 



FF 


BANKO 


BANK1 


















bO 
DF 












' • 


DO 


/ 



CONTROL 
REGISTERS 



Each Register Pointer (RP) can independently point to any of 32 
8-byte blocks of set one. The block selected by RPO is accessed 
in address space C0-C7, while the block selected by RP1 is 
accessed in address space C8-CF. Memory space from CO-CF 
can only be accessed if pointed to by the RPs. 



REGISTER ADDRESSING ONLY 




ALL 

ADDRESSING 

MODES 



MAY BE POINTED TO BY REGISTER POINTER 



INDIRECT REGISTER, 

INDEXED, 

STACK, OR 

DMA MODES 



Figure 3-2. Supers Register File Address Spaces 



The first set consists of three subsets of regis- 
ters. The bottom sixteen registers (CO|^-CF^) 
are available for use as accumulators or working 
registers. The middle sixteen registers (DO^- 
DF^) are used for system registers — Stack 
Pointer, Flag register, I/O ports, and so forth. 
The upper 32 bytes (EOj^-FFj^) consist of two 
banks of registers. Each bank is selected by d 
bit located in the Flag register called the Bank 
Address bit. These two bahks, a total of 64 
bytes, are used for Mode and Control registers. 
Only 38 of these 64 bytes are currently used. The 
remaining 26 bytes are reservjed for future 
expansion. 

Registers can be accessed as either 8- or 16-bit 
registers using Register, Indirect Register, or 
Indexed addressing modes. For register addresses 
COj^ to FF^, the addressing mode used deter- 
mines the actual register being accessed. 
Registers accessed as 16-bit registers are treated 
as even-odd register pairs, with the most signifi- 



cant byte of data stored in the even-numbered 
register and the least significant byte stored in 
the next higher odd-numbered register (Figure 
3-3). 



I MSB I LSB I n = 



EVEN ADDRESS 



Figure 3-3. 16-Bit Register Addressing 

With few exceptions, all instructions that refer- 
ence or modify a register may do so to any of the 
325 8-bit registers or 176 16-bit register pairs, 
regardless of the particular register, as long as 
the proper addressing mode is used. The instruc- 
tions operate on I/O ports, system registers, mode 
and control registers, and general- pur pose regis- 
ters without the need for special-purpose instruc- 
tions. 

Usage and access are shown in Table 3-1. 
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Table 3-1. SuperB Register File 



Registers 



Usage 



00-BF 



General-purpose registers 



Register, Indirect Register, or 
Indexed modes, via on-chip DMA 
operation^, or as part of inter- 
nal stack 



CO-FF Set Two General-purpose registers 



Indirect Register or Indexed 
modes, via on-chip DMA opera- 
tions, or as part of internal 
stack 



CO-FF Set One Working registers only Register mode 
DO-DF Set One System registers Register mode 

EO-FF Set One Mode and control registers Register mode 



RP0(R214) RP1(R215) 

I 1 1 1 I 1 ^ 1 I 10 10 I I 

j I SELECTS RPO 

1 f— ^ ' 

I 1 1 1 I 1 1 1 



The instructions can access 8-bit registers or 
16-bit register pairs using either 4-bit or 8-bit 
address fields. When using 4-bit register 
addressing, the register file is logically divided 
into 32 groups of 8 working registers, as shown in 
Figure 3-4. All the registers in a working regis- 
ter set have the same value for their five most- 
significant address bits. The two Register 
Pointers (RPO and RP1) are system registers that 
contain the base addresses of two active working 
register groups. 



00000 XXX 



Figure 3-4. Working Register Groups 

Note that 4-bit register addressing (Figure 3-5) 
is a Register addressing mode so that the regis- 
ters accessible by this mode include the mode and 
control registers, system registers, and working 
register groups. 



REGISTER 
ADDRESS 
(R118) 



-^ R6 OPC 



Figure 3-5. Worthing Register Addressing 

Working registers are typically specified by short 
format instructions; when a working register 
destination is used in the instruction, only four 
bits of address are needed to specify the regis- 
ter; one) bit selects the appropriate Register 
Pointer and three bits provide the least-signifi- 
cant bits of the register address. The 
five most-significant bits of the address come 
from the selected Register Pointer and together 
they form an 8-bit address. Applications using 
working registers require fewer bytes and have a 
reduced execution time. 

The Register Pointer also speeds context switching 
when processing interrupts or changing tasks. A 
special Set Register Pointer (SRP) instruction is 
provided for setting the Register Pointer 
contents. 
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RP0(R214) 
I 1 1 1 I I 



RP1 (R215) 
— ►! 10 10 I 0^ 



SELECTS RP1 



I 

^^~ R11 

I 1 1 I 1 1 1 1^^ 



SPECIFIES WORKING I 
REGISTER ADDRESSING L. 



8-BIT ADDRESS 
FROM INSTRUCTION 



REGISTER ADDRESS 



(R163) I 10 10 I 1 1 j 



Figure 3-6. 8-Bit Worl(ing Register Addressing 

Not all instructions have 4-bit addressing modes, 
but the active working registers can still be 
accessed using 8-bit addressing without having to 
know the contents of the Register Pointers. 
Figure 3-6 shows how this works. The upper four 
bits of the 8-bit address contain 1100 to specify 
working register addressing. Bit 3 selects Regis- 
ter Pointer or 1, which supplies the upper five' 
bits of the final address while the lower three 
bits come from bits 0-2 of the original 8-bit 
address. 

Any address in the range CO^-CFj^ (R192-R207) 
will invoke working register addressing. There- 
fore the registers physically located at these 
addresses can only be accessed when selected by a 
Register Pointer (see Figure 3-2). 

After Reset, the register pointers will be set to 
RPO = CO^ and RP1 = 08^. 



3.3 SYSTEM REGISTERS AND MODE AhD 
CONTROL REGISTERS 

The system registers govern the operation of the 
CPU and can be accessed using any of the instruc- 
tions that reference the register file using 
Register addressing mode. These registers can be 
accessed as working registers. Table 3-2 shows 
the system registers. 

The Supers uses a 16-bit Program Counter (PC) to 
control the sequence of instructions in the 
currently executing program. The PC is not an 
addressable register. 

Mode and control registers are used to transfer 
data, configure the mode of operation, and control 
the operation of the on-chip peripherals. These 
registers are accessed using Register addressing 
mode and are shown in Table 3-3. These registers 
can be accessed as working registers. The current 
"bank" is determined by bit Dg in the Flag 
register (R213). 



3.4 PROGRAM AND DATA MEMORY 

Program memory is memory that can hold code or 
data. Instruction code can be fetched from 
program memory, data can be read from program 
memory and, if external program memory is imple- 
mented in RAM, data or code can be written to 
program memory. Memory addresses are 16 bits 
long, allowing a maximum of 64K bytes of program 



T^le 3*2. Systen Registers 



Deciml 


Hexadeciaal 






Address 


Address 


Register Nane 


Identifier 


222 


DE 


System Mode 


SYM 


221 


DD 


Interrupt Mask Register 


IMR 


220 


DC 


Interrupt Request Register 


IRQ 


219 


DB 


Instruction Pointer (Bits 7-0) 


IPL 


218 


DA 


Instruction Pointer (Bits 15-8) 


IPH 


217 


D9 


Stack Pointer (Bits 7-0) 


SPL 


216 


D8 


Stack Pointer (Bits 15-8) 


SPH 


215 


D7 


Register Pointer 1 


RP1 


214 


06 


Register Pointer 


' RPO 


213 


D5 


Program Control Flags 


FLAGS 


212 


D4 


Port 4 


P4 


211 


D3 


Port 3 


P3 


210 


D2 


Port 2 . 


P2 


209 


D1 


Port 1 


PI 


208 


DO 


Port 


PO 
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T^le 3-3. Node and Cbntrol Registers 



Deciaal 


Hexadecinal 










Address 


Address 


Register Naae 






Identifier 


Bank 


Registers 










255 


FF 


Interrupt Prior 


ity 




IPR 


254 


FE 


External Memory 


' Timing 




EMT 


253 


FD 


Port 2/3B^ Interrupt Pending 


P2BIP 


252 


FC 


Port 2/3A Interrupt Pending 


P2AIP 


251 


FB 


Port 2/3D Mode 






P2DM 


250 


FA 


Port 2/3C Mode 






P2CM 


249 


F9 


Port 2/3B Mode 






P2BM 


248 


F8 


Port 2/3A Mode 






P2AM 


247 


F7 


Port 4 Open-Drain 




P40D 


246 


F6 


Port 4 Direction 




P4D 


245 


F5 


Handshake 1 Control 




H1C 


244 


F4 


Handshake Control 




HOC 


241 


F1 


Port Mode 






PM 


240 


FO 


Port Mode 






POM 


239 


EF 


UART Data 






UIO 


237 


ED 


UART Interrupt 


Enable 




UIE 


236 


EC 


UART Receive Control 




URC 


235 


EB 


UART Transmit Control 




UTC 


229 


E5 


Counter 1 Capture Low 




C1CL 


228 


E4 


Counter 1 Capture High 




C1CH 


227 


E3 


Counter Capture Low 




COCL 


226 


E2 


Counter Capture High 




COCH 


225 


El 


Counter 1 Control 




C1CT 


224 


EO 


Counter Control 




COCT 


Bank 1 


Registers 










255 


FF 


Wake-Up Mask 






WUMSK 


254 


FE 


Wake-Up Match 






WUMCH 


251 


FB 


UART Mode B 






UMB 


250 


FA 


UART Mode A 






UMA 


249 


F9 


UART Baud-Rate 


Generator 


' Low 


UBGL 


248 


F8 


UART Baud-Rate 


Generator 


' High 


UBGH 


241 


F1 


DMA Count Low 






DCL 


240 


FO 


DMA Count High 






DCH 


229 


E5 


Counter 1 Time 


Constant 


Low 


C1TCL 


228 


E4 


Counter 1 Time 


Constant 


High 


C1TCH 


227 


E3 


Counter Time 


Constant 


Low 


COTCL 


226 


E2 


Counter Time 


Constant 


High 


COTCH 


225 


El 


Counter 1 Mode 






C1M 


224 


EO 


Counter Mode 






COM 



s 
memory. The bottom of program memory is in the 

on-chip ROM; the remaining program memory can be 

implemented external to the SuperS. 

Data memory is memory that can hold only data to 
be read or written, not instruction code; instruc- 
tion fetches never reference data memory. Data 
memory is always implemented external to the 
Supers, 



External data memory can be incorporated with or 
separated from the external program memory address 
space. To implement separate program and data 
memory address spaces external to the SuperS, a 
port output pin (P35) must be defined as the, Data 
Memory select (CM) output. This output remains 
high when fetching instructions or accessing data 
in the program memory address space and goes low 
when accessing data in the data memory address 
space. Thus, this signal can be used to segregate 
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65535 

THIS BOUNDARY 1 
DEPENDS ON > 
ROM SIZE 

32 


EXTERNAL 
PROGRAM 
MEMORY 







INTERRUPT VECTORS 



. ON-CHIP 

^ ROM 



EXTERNAL 

DATA 
MEMORY 



PROGRAM MEMORY 



DATA MEMORY 



Figure 3-7. Program and Data Memory Address Spaces 



the program and data spaces external to the 
Supers. Separate forms of Load instructions are 
used to access the two memory address spaces: the 
LDC instruction and its derivatives access program 
memory, and the IDE instruction and its deriva- 
tives access data memory. 

Program and data memory maps are illustrated in 
Figure 3-7. 

To access memory beyond the on-chip ROM, Ports 
and 1 must be configured as a memory interface. 
Port 1 can be configured as a multiplexed 
address/data bus (ADq-AD?)' ^^^^ providing address 
lines Ag-Ay and data lines Dg-Dy. Port can be 
configured on an individual bit basis for up to 
eight additional address lines (Ag-A'j5). Both 
parts are supported by the control lines Address 
Strobe (?^, Data Strobe (TO, and Read/Write 
(R/W). 

In the ROMless version. Port 1 is automatically 
configured as a multiplexed address/data bus. 
Port bits 0-4 will be configured as address bits 
A8-A12 ^^ Reset, but any Port bit may be defined 
as either I/O or address as needed. 

For more details on external memory interface, see 
section 12.3. , 

No matter which version of the SuperS is used, the 
first 32 bytes of program memory are reserved for 
the interrupt vectors. Thus the first address 
available for a user program is location 32. This 
address is automatically loaded into the Program 
Counter whenever a hardware Reset occurs. 



5.5 CPU AND USER STACKS 

The Supers uses a stack for implementing 
subroutine calls and returns, interrupt process- 



ing, and general dynamic storage (via the Push and 
Pop instructions) , The SuperS provides hardware 
support for stack operations from either the 
register file or data memory. Stack location 
selection is under software control via the 
External Memory Timing register (R254, Bank 0). 

Register pair RR216 forips the 16-bit Stack 
Pointer, used for CPU stack operations. The 
address is stored with the most significant byte 
in R216 and least significant in R217 (Figure 
3-S). 



R217(D9)SPL 



LOWER BYTE 



STACK POINTER LOW 



R216(D8)SPH 



STACK POINTER HIGH 



Figure 3-8. Stack Pointer 



The Stack Pointer is decremented before a Push 
operation and incremented after a Pop operation. 
The stack address always points to the last data 
stored on the top-of-stack. 

The stack is used to hold the return address for 
CALL instructions ar^d interrupts, as well as 
data. The contents of the Program Counter are 
saved on the stack during a CALL instruction and 
restored during a RET instruction. During inter- 
rupts, the contents of the Program Counter and 
Flag register are saved on the stack. The IRE F 
instruction restores them (Figure 3-9). 

When the SuperS is configured to use an internal 
stack (the register file)-, register R217 serves as 
the Stack Pointer and register R216 is a general- 
purpose register. However, if an overflow or 
underflow condition occurs due to the incrementing 
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TOP OF - 
STACK 



STACK CONTENTS 
AFTER A CALL 
INSTRUCTION 



HIGH ADDRESS 



TOP OF - 
STACK 



LOW ADDRESS 



STACK CONTENTS 
AFTER A NORMAL 
INTERRUPT CYCLE 



Figure 3-9. Stack Operations 



Table 3-4. User Stack Operations SiMmary 







Stack Location 


—_— 






Register 


Progran 


Data 


Stack Type* 


Operation 


File 


Ne«ory 


Naiory 


Ascending 


PUSH to stack 


PUSHUI 


LDCPI 


LDEPI 




POP from stack 


POPUD 


LDCD 


LDED 


Descending 


PUSH to stack 


PUSHUD 


LDCPD 


LDEPD 




POP from stack 


POPUI 


LDCI 


LDEI 



Ascending stack goes from low to high addresses within memory or 
register file. Descending stack goes from high to low addresses 
within meijiory or register file. 



and decrementing of normal stack operations, the 
contents of register R216 are affected. 

The Supers also provides for user-defined stacks 
in both the register file and in program or data 
memory. These stacks can be malde to increment or 
decrement on Push and Pop. Table 3-4 summarizes 
the kinds of stacks and the instructions used. 



3.6 INSTRUCTION POINTER (IP) 

The Supers provides hardware support for implemen- 
tation of threaded-code languages such as Forth. 
An important part of that support is in the form 
of a special register called the Instruction 
Pointer (IP) (Figure 3-10). The Instruction 
Pointer is made up of register pair RR218, with 
R218 holding the most significant byte of a memory 
address and R219 the least significant byte, 

A threaded-code language may be considered to have 
created a highef level imaginary machine within 
the actual hardware machine. For comparison 
purposes, the IP is to the imaginary machine as 
the^ Program Counter is to the actual hardware 
machine. 



R218(DA)IPH 
INSTRUCTION POINTER HIGH 



-HIGHBYTE(IP8-IP15) 



R219(DB)IPL 
INSTRUCTION POINTER LOW 



Dy De Ds D4 D3 D2 Di Do 



-LOW BYTE (IP0-IP7) 



Figure 3-10. instruction Pointer 



The IP is used by three special instructions 
called NEXT, ENTER, and EXIT. The instruction 
NEXT passes control from the hardware machine to 
the imaginary machine, while ENTER and EXIT are 
the imaginary machine equivalents of subroutine 
CALLS and RETURNS in the hardware machine. 

The IP can also be used in the fast interrupt 
processing mode for special interrupt handling 
(see section 6.2).' It can be used either for 
interrupt processing or imaginary machine process- 
ing, but not for both at the same time. 
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4.1 INTRODUCTION 

Instructions are stored as lists of bytes in 
program memory that are fetched via instruction 
fetches using the Program Counter, Instructions 
will indicate both the action to be performed and 
the data to be operated on. The method used to 
determine the location of the data operand is 
called the addressing mode. 

Operands specified in SuperS instructions are 
either condition codes, immediate data, or the 
designation of a register file, program memory, or 
data memory location. 

For the SuperS, there are seven explicit address- 
ing modes (i.e., addressing modes designated by 
the programmer): 

• Register (R) 

• Indirect Register (IR) 

• Indexed (X) 

• Direct Address (DA) 

• Indirect Address (lA) 

• Relative Address (RA) 

• Immediate (IM) 

Not all modes are available with each instruction 
(refer to the individual instruction descriptions 
in section 5.5). 



Accessing an individual register requires specify- 
ing an 8-bit address in the range 0-255 or a 
working register's 4-bit address. The most signi- 
ficant bit of the 4-bit working register address 
selects one of two Register Pointers: if this bit- 
is 0, then R214 (RPO) is selected; if it is 1, 
then R215 (RP1) is selected. The address of the 
actual register being accessed is formed by the 
concatenation of the high order five bits of the 
value contained in the selected Register Pointer 
with the remaining three bit address supplied by 
the instruction. 

A register pair can be used to specify a 16-bit 
value or memory address. The Load Constant 
instruction and its derivatives (LDC, LDCD, LDCI, 
LDCPD, LDCPI) load data from program memory; the 
Load External instruction and its derivatives 
(LDE, LDED, LDEI, LDEPD, LDEPl) load from program 
memory. See the instruction set in Chapter 5 for 
further details. 



4.2 REGISTER ADDRESSING (R) 

In the Register addressing mode, the operand value 
is ' the contents of the specified register or 
register pair (Figures 4-1 and 4-2). 



Registers CO^-FF|^ (set one) can only 
accessed with the Register addressing mode. 



be 



PROGRAM MEMORY 



REGISTER FILE 



8BIT REGISTER 
FILE ADDRESS . 



ONE-OPERAND 

INSTRUCTION 

EXAMPLE' 



i^ 



POINTS TO ONE REGISTER 
IN REGISTER FILE 



VALUE USED IN 
INSTRUCTION EXECUTION 



Figure 4-1 . Register Addressing 



REGISTER FILE 



MSB POINTS TO 
RPO OR RP1 



4.BIT WORKING 
REGISTER , 



PROGRAM MEMORY 



TWO-OPERAND 
INSTRUCTION 



V dst T" 



/- 



POINT TO THE 

WORKING REGISTER 

(10F8) 




SELECTED RP 
POINTS TO 
ORIGIN OF 
WORKING 
REGISTER 
GROUP 



Figure 4-2. Working Register Addressing 
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8-BIT REGISTER 
FILE ADDRESS 



PROGRAM MEMORY 



^r 



ONE-OPERAND ^ 

INSTRUCTION >^ 

EXAMPLE^ 



POINTS TO ONE REGISTER 
IN REGISTER FILE 

ADDRESS OF 
OPERAND USED 
BY INSTRUCTION ^ 



VALUE USED IN 

INSTRUCTION^ 

EXECUTION 



REGISTER FILE 



y- 



7^ 



Figure 4-3. Indirect Register Addressing to Register File 



PROGRAM MEMORY 



4-BIT WORKING 
REGISTER ADDRESS " 



REGISTER FILE 



MSB POINTS TO 
RPO OR RP1 



5^ 



J 3 L&DS 

POINT TO WORKING 
REGISTER (1 OF 8) 



value used in 
instruction" 



SELECTED RP 
POINTS TO 
ORIGIN OF 
i WORKING 
REGISTER 
GROUP 



Figure 4-4. Indirect Worldng Register Addressing to Register File 



REGISTER FILE 



EXAMPLE INSTRUCTION 
REFERENCES PROGRAM - 
MEMORY 



POINTS TO 
REGISTER PAIR 



PROGRAM MEMORY 



16-BIT 

ADDRESS 
I POINTS TO 
I PROGRAM 

MEMORY 



VALUE USED IN 
INSTRUCTION" 



Figure 4-5. Indirect Register Addressing to Program Memory 
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4.3 INDIRECT REGISTER ADDRESSING (IR) 



4.4 INDEXED ADDRESSING (X) 



In the Indirect Register addressing mode, the 
content of the specified register or register pair 
is the address of the operand (Figures 4-3, 4-4, 
4-5, and 4-6). Depending on the instruction used, 
the aptual address may point to a register, 
program memory, or data memory. 

Any general-purpose byte register can be used to 
indirectly address another register; any general- 
purpose register pair can be used to indirectly 
address a memory location. 

General-purpose registers CO|^-FF|^ (set two) 
can be accessed only with the Indirect Register 
and Indexed addressing modes. 



The Indexed addressing mode involves adding an 
offset to a base address during instruction execu- 
tion to calculate the effective address of the 
operand. The Indexed addressing mode can be used 
to access registers or memory areas. 

For register accesses, an 8-bit base address given 
in the instruction is added to an 8-bit offset 
given in a working register (Figure 4-7). 
General-purpose registers COj^-FF^ (set two) 
can be accessed only with the Indirect Register 
and Indexed addressing modes. The LD instruction 
is the only instruction that allows Indexed 
addressing of the registers. 



MSB POINTS TO 
RP0ORRP1 



4-BIT WORKING 
REGISTER ADDRESS y 

EXAMPLE 
INSTRUCTION ,_ 
REFERENCES EITHER y L- 
PROGRAM MEMORY / 
OR DATA MEMORY 



PROGRAM MEMORY 



;\r 



NEXT 2 BITS POINT 

TO WORKING REGISTER 

PAIR (1 OF 4) 

LSB SELECTS 



REGISTER FILE 



INSTRUCTION ^ 



PROGRAM MEMORY 

OR 

DATA MEMORY 



SELECTED RP 
I POINTS TO 
I ORIGIN OF 
I WORKING 

REGISTER 

GROUP 



16-BIT 
' ADDRESS 
POINTS TO 
PROGRAM 
OR DATA 
MEMORY 



Figure 4-6. Indirect Working Register Addressing to Program or Data IMemory 



REGISTER FILE 



MSB POINTS TO 
RPO OR RP1 



TWO-OPERAND 
INSTRUCTION - 
EXAMPLE 




Figure 4-7. Indexed Addressing to Register File 
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For memory accesses, the base address is held in 
the working register pair designated in the 
instruction and an 8-bit or 16-bit offset given in 
the instruction is added to that base address 
(Figures 4-8 and 4-9). In the short offset 



Indexed addressing mode, the 8-bit displacement is 
treated as a signed integer in the range -128 to 
+127. Only the LOC and IDE instructions^ allow 
Indexed addressing of memory. 



REGISTER FILE 



MSB POINTS TO 
RP0ORRP1 



PROGRAM MEMORY 



4-BIT WORKING 
REGISTER address' 



^ next 2 bits 
"point to"*' 

WORKING 
REGISTER 
PAIR 
(10F4) 



SELECTED R 
POINTS TO 
ORIGIN OF 
WORKING 
REGISTER 
GROUP 



16-BIT 
ADDRESS 
ADDED TO 
OFFSET 



V. ) 

LSB SELECTS 



PROGRAM MEMORY 

OR 

DATA MEMORY 



8 BITS VlXlSBITS 



„ VALUE USED 
IN INSTRUCTION 



Figure 4-8. Indexed Addressing to Program or Data IVIemory with Short Offset 



REGISTER FILE 



MSB POINTS TO 
RPO OR RP1 
f » 



PROGRAM MEMORY 



4-BIT WORKING 
REGISTER address" 



!^ 



_j next 2 bits 
"point to"* 

WORKING 
REGISTER 
PAIR 



s 



PROGRAM MEMORY 

OR 

DATA MEMORY 



SELECTED RP 
POINTS TO 
ORIGIN OF 
WORKING 
REGISTER 
GROUP 



16-BIT 
ADDRESS 
ADDED TO 
OFFSET 



.VALUE USED 
IN INSTRUCTION 



Figure 4-9. Indexed Addressing to Program or Data Memory 
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4.5 DIRECT ADDRESSING (DA) 

In Direct addressing mode, as seen in Figures 4-10 
and 4-11, the 16-bit memory address of the operand 
is given in the instruction. This mode is used by 
the Jump and Call instructions to specify the 
16-bit destination that is loaded into the Program 
Counter to implement the Jump or Call. This mode 
is also supported by the LDE and LDC instructions 
to specify the source or destination memory 
address for a load between a register and a memory 
location. Memory loads with LDC and LDE can use 
the Direct or Indirect Register addressing modes. 



PROGRAM MEMORY 



UPPER ADDR BYTE 



LOWER ADDR BYTE 
dst/sro I OR 1 - 



MEMORY 
I ADDRESS U 



LSB SELECTS 

PROGRAM OR 

- DATA MEMORY 

= PROGRAM MEMORY 

1 = DATA MEMORY 



Figure 4-10. Direct Addressing for Load Instructions 



PROGRAM MEMORY 



PROGRAM MEMORY 
ADDRESS USED 



Only the CALL instruction uses this addressing 
mode. 

PROGRAM MEMORY 



PRESENT _^ 
INSTRUCTION"*" 



:?^ 



- NEXT INSTRUCTION 



LSB MUST BE ZERO 



LOWER ADDR BYTE 



UPPER ADDR BYTE 



PROGRAM MEMORY 
LOCATIONS 0-255 



Figure 4-1 2. indirect Addressing 



4.7 RELATIVE ADDRESSING (RA) 

In the Relative addressing mode (Figure 4-13), a 
twos-complement signed displacement in the range 
-128 to +127 is specified in the instruction and 
added to the value contained in the Program 
Counter. The result is the address of the next 
instruction to be executed. Prior to the add, the 
Program Counter contains the address of the 
instruction following the current instruction. 



LOWER ADDR BYTE 



UPPER ADDR BYTE 



Figure 4-1 1 . Direct Addressing for Call and 
Jump Instructions 



The Relative addressing mode is supported by 
several program control type instructions: BTJRF, 
BTJRT, DJNZ, CPIJE, CPIJNE, and JR. 



PROGRAM MEMORY 



PROGRAM MEMORY 
ADDRESS USED 



4.6 INDIRECT ADDRESSING (lA) 

In the Indirect addressing mode (Figure 4-12), the 
instruction specifies a pair of memory locations 
found in the lowest 256 bytes of program memory. 
The selected pair, in turn, contains the actual 
address of the next instruction to be executed. 

Since the Indirect addressing mode assumes that 
the operand is located in the lowest 256 bytes of 
memory, only an 8-bit address is supplied in the 
instructioni the upper bytes of the destination 
address are assumed to be all Os. 



CURRENT 
INSTRUCTION " 





"V 




CURRENT >v 




■^ PC VALUE ^ >->, 


DISPLACEMENT , 


1 r4 


i«^ V " > 


OPCODE 


SIGNED 




DISPLACEMENT 
VALUE 







Figure 4-1 3. Relative Addressing 
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4.8 INNEDIATE ADDRESSING (IN) 

In the Immediate addressing mode (Figure 4-14), 
the operand value used in the instruction is the 
value supplied in the operand field itself. The 
operand may be a byte or word in length, depending 
on the instruction. The Immediate addressing mode 
is useful for loading constant values into 
registers* 



PROGRAM MEMORY 



THE OPERAND VALUE IS IN THE INSTRUCTION 



Figure 4-14. Immediate Addressing 
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3.1 FUNCTIONAL SUMMARY 

SuperB instr,uctions can be divided functionally 
into the following seven groups: 

• Load 

• Arithmetic 

• Logical 

• Program Control 

• Bit Manipulation 

• Rotate and Shift 

• CPU Control 

Table 5-1 shows the instructions belonging to each 
group and the number of operands required for 
each, where "src" is the source operand, "dst" is 
the destination operand, and "cc" is the condition 
code. 

With few exceptions, all instructions that refer- 
ence a register may do so to any of the 325 8-bit 
registers ot 176 16-bit register pairs. Thus, the 
same instructions are used to operate on I/O 
ports, system registers, mode and control regis- 
ters, and general-purpose registers. 

The exceptions to the above are as follows: 

• The Decrement and Jump on Non-Zero (DJNZ) 
instruction's register operand must be a 
general-purpose byte register. 

• The following control registers are write-only 
registers: Port Mode, Port 2/3 A Mode, Port 2/3 
B Mode, Port 2/3 C Mode, Port 2/3 D Mode, 
Handshake Control, and Handshake 1 Control. 

• The Flags register (R21 3) cannot be the destin- 
ation for an instruction that alters the flags 
as part of its operation. 



5.2 PROCESSOR FUGS 

Flag register R213 supplies the status of the 
SuperB CPU at any time. The flags and their bit 
positions are shown in Figure 5-1. 



R213(D5) FLAGS 
SYSTEM FLAG REGISTER 




BANK ADDRESS 
FAST INTERRUPT STATUS 
HALF-CARRY FLAG 
DECIMAL ADJUST 



Figure 5-1 . Flag Register 



This register contains eight bits of status infor- 
mation that are set or cleared by CPU operations. 
Four of the bits (C, V, Z, and S) are testable for 
use with conditional Jump instructions. Two of 
the flags (H and D) are not testable and are used 
only for BCD arithmetic. All flags are restored to 
the pre-interrupt value by a return from 
interrupt. 

Bank Address Flag (BA). This bit selects which of 
the two groups of mode and control registers is 
active. 

Carry Flag (C), This flag is set to 1 whenever 
the result of an arithmetic operation generates a 
carry-out of or borrow into the high order bit 7. 
It is cleared to whenever an operation does not 
generate a carry or borrow condition. This flag 
can be set, cleared, and complemented by the Set 
Carry Flag (SCF), Reset Carry Flag (RCF), and 
Complement Carry Flag (CCF) instructions. 

Decimal- Ad just Flag (D). The Decimal-Adjust flag 
is used for BCD arithmetic. It is set to 1 
following a subtraction operation and cleared to 
following an addition operation. Since the 
algorithms for correcting BCD addition and 
subtraction are different, this flag is used to 
specify the type of instruction last executed so 
that the subsequent Decimal Adjust (DA) operation 
can function properly. It is not normally used as 
a test flag by the programmer. 

Fast Interrupt Status Flag (FIS). This bit is set 
to 1 during a Fast Interrupt and cleared to 
during the Interrupt Return (IRET), 
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Table 3-1. Instruction GroMp SuHiary 



Nrienonic 



Operands 



Instruction 



Load Instructions 



CLR 


dst 


LD 


dstjsrc 


LDB 


dst,src 


LDE 


dst,src 


LDC 


dst,8rc 


LDED 


dst,8rc 


LDCD 


dst,src 


LDEI 


dst,src 


LDCI 


dstjsrc 


LOEPD 


dst,src 


LbCPD 


dstjSrc 


LDEPI 


dstjSrc 


LDCPI 


d8t,8rc 


LDW 


d8t,src 


POP 


d8t 


POPUD 


dst,8rc 


POPUI 


d8t,src 


PUSH 


src 


PUSHUD 


dstjSrc 


PUSHUI 


dst,8rc 



Clear 

Load 

Load Bit 

Load Data Memory 

Load Program memory 

Load Data Memory and Decrement 

Load Program Memory and Decrement 

Load Data Memory and Increment 

Load Program Memory and Increment 

Load Data Memory with Pre-Decrement 

Load Program Memory with Pre-Decrement 

Load Data memory with Pre-Increment 

Load Program Memory with Pre-Increment 

Load Word 

Pop 

Pop User Stack (Decrementing) 

Pop User Stack (Incrementing) 

Push 

Push User Stack (Decrementing) 

Push User Stack (Incrementing) 



Arithaetic Instructions 



ADC 


dstjsrc 


Add with Carry 


ADD 


dst , src 


Add 


CP 


dst,src 


Compsre 


DA 


dst 


Decimal Adjust 


DEC 


dst 


Decrement 


DECW 


dst 


Decrement Word 


DIV 


dst, src 


Divide 


INC 


dst 


Increment 


INCW 


dst 


Increment Word 


MULT 


dst, src 


Multiply 


SBC 


dst, src 


Subtract with Carry 


SUB 


dst , src 


Subtract 



Logical Instructions 



AND 


dst, src 


Logical AND 


COM 


dst 


Complement 


OR 


dst, src 


Logical OR 


XOR 


dst, src 


Logical Exclusive OR 



PrograM Control Instructions 



BTJRF 


dst, src 


BTJRT 


dst, src 


CALL 


dst 


CPIJE 


dst, src 



Bit Test and Jump Relative on False 
Bit Test and Jump Relative on True 
Call Procedure 
Compare, Increment and Jump on Equal 
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Table 5-1 • Instruction Group Summary (Continued) 



Nneaonic 



Operands 



Instruction 



Progran Control Instructions (Continued) 



CPIJNE 


dstjsrc 


Compare, Increment and Jump on Non-Equal 


DJNZ 


r,dst 


Decrement Register and Jump on Non-Zero 


ENTER 




Enter 


EXIT 




Exit 


IRET 




Interrupt Return 


JP 


cc ,dst 


Jump on Condition Code 


JP 


dst 


Jump Unconditional 


JR 


cc,dst 


Jump Relative on Condition Code 


JR 


dst 


Jump Relative Unconditional 


NEXT 




Next 


RET 




Return 


WFI 




Wait for Interrupt 


Bit Manipulation Instructions 


1 


BAND 


dst,src 


Bit AND 


BCP 


dstjsrc 


Bit Compare 


BITC 


dst 


Bit Complement 


BITR 


dst 


Bit Reset 


BITS 


dst 


Bit Set 


BOR 


dst,src 


Bit OR 


BXOR 


dst,src 


Bit XOR 


TCM 


dstjsrc 


Test Complement Under Mask 


TM 


dst,src 


Test Under Mask 


Rotate and 


Shift Instructions 


t 


RL 


dst 


Rotate Left 


RLC 


dst 


Rotate Left through Carry 


RR 


dst 


Rotate Right 


RRC 


dst 


Rotate Right through Carry 


SRA 


dst 


Shift Right Arithmetic 


SWAP 


dst 


Swap Nibbles 


CPU Control 


Instructions 




CCF 




Complement Carry Flag 


DI 




Disable Interrupts 


EI 




Enable Interrupts 


NOP 




No Operation 


RCF 




Rfeset Carry Flag 


SBO 




Set Bank 


SB1 




Set Bank 1 


SCF 




Set Carry Flag 


SRP 


src 


Set Register Pointers 


SRPO 


src 


Set Register Pointer 


SRP1 


src 


Set Register Pointer 1 
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Half-Carry Flag (H). The Half-Carry flag is set 
to 1 whenever an addition generates a carry-out of 
bit 3 or subtraction generates a borrow into bit 
3. The Half-Carry flag is used by the Decimal 
Adjust (DA) instruction to convert the binary 
result of a previous addition or subtraction into 
the correct decimal (BCD) result. It is not 
normally used as a test flag by the programmer. 



Zero Flag (Z). During arithmetic and logical 
operations, the Zero flag is set to 1 if the 
result is zero and cleared to if the result is 
non-zero. When testing bits in a register or when 
shifting or rotating, the Zero flag is set to 1 if 
the result is zero; if the result is not zero, the 
flag is cleared to 0. 



Overflow Flag (V). This flag is set to 1 during 
arithmetic, rotate, or shift operations that 
result in a value greater than +127 or less than 
-128 (the maximum and minimum numbers that can be 
represented in twos-complement form); it is 
cleared to whenever the result is a value within 
these ranges. This flag is also cleared to 
following logical operations. 



3.3 CONDITION CODES 

Flags C, Z, S, and V control the operation of the 
"conditional" Jump instructions. Sixteen 
frequently used combinations of flag settings 
are encoded in a 4-bit field called the condition 
code (cc), which forms a part of the conditional 
instructions (bits 4-7). 



Sign Flag (S). When performing arithmetic opera- 
tions on signed numbers, binary twos-complement 
notation is used to represent and process informa- 
tion. A positive number is identified by a in 
the most significant bit position; when this 
occurs, the Sign flag is also cleared to 0. A 
negative number is identified by a 1, in the most 
significant bit position and therefore the Sign 
flag would be set to 1. 



The condition codes and the flag settings they 
represent are listed in Table 5-2. 



5.4 NOTATION AND BINARY ENCODING 

The following sections describe the symbols used 
for operands and status flags, and the flag 
settings and their meanings. 



Table 5-2. Condition Codes 


Binary 


Hnenonic 


Meaning 




Flags Set 


0000 


F 


Always False 




_ ; 


1000 




Always True 




- 


0111* 


C 


Carry 




C = 1 


1111* 


NO 


No Carry 




C = 


0110* 


Z 


Zero 




Z = 1 


1110* 


NZ 


Not Zero 




z = q 


1101 


PL 


Plus 




S = 


0101 


MI 


Minus 




S = 1 


0100 


OV 


Overflow 




V = 1 


1100 


NOV 


No Overflow 




V = 


0110* 


EQ 


Equal 




Z = 1 


1110* 


NE 


Not Equal 




2 = 


1001 


GE 


Greater than or equal 




(S XOR V) = 


0001 


LT 


Less than 




(S XOR V) r 1 


1010 


GT 


Greater than 




(Z OR (S XOR V)) = 


0010 


LE 


Less than or equal 




(Z OR (S XOR V)) = 1 


1111* 


UGE 


Unsigned greater than 


or equal 


C = 


0111* 


ULT 


Unsigned less than 




C = 1 


1011 


UGT 


Unsigned greater than 




(C = ANP Z = 0) = 1 


0011 


ULE 


Unsigned less than or 


equal 


(C OR Z) = 1 



Indicates condition codes that relate to two different mnemonics but test 
the same flags. For example, Z and EQ are both True if the Zero flag is 
set, but after an ADD instruction, Z would probably be used, while after a 
CP instruction, EQ would probably be usecj. 
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Table 5>3. Notation and Binary Encoding 



Notation 



Meaning 



Actual Operand/Range 



rb 
rO 



Rb 



RR 



lA 



Condition code 
Working register only 
Bit b of working register 
Bit of working register 
Working register pair 
Register or working register 



Bit b of register or working 
register 

Register pair or working 
register pair 

Indirect addressing mode 



Ir 


Indirect working register only 


IR 


Indirect register or working 




register 


Irr 


Indirect working register only 


IRR 


Indirect register pair or 




working register pair 


X 


Indexed addressing mode 


XS 


Indexed (Short Offset) 




addressing mode 


XL 


Indexed (Long Offset) 




addressing mode 


DA 


Direct addressing mode 


RA 


Relative addressing mode 


IM 


Immediate addressing mode 


IML 


Immediate (Long) 



addressing mode 



See condition code list (Table 5-2) 

Rn: where n = 0-15 

Rn #b: where n = 0-15 and b = 0-7 

Rn: where n r 0-15 

RRp: where p = 0,2, 4,..., 14 

Reg: where reg represents a number in the range 

0-255 
Rn: where n = 0-15 
Reg #b: where reg represents a nLBnber in the 

range 0-255 and b = 0-7 
Rn #b: where n = 0r15 and b = 0-7 
Reg: where reg reprsents an even number in the 

range 0-254 
RRp: where p = 0,2, ...,14 
# addrs: where addrs represents an even number 

in the range 0-254 
©Rn: where n = 0-15 
©reg: where reg represents a number in the range 

0-255 
©Rn: where n = 0-15 
@RRp: where p = 0,2,..., 14 
©reg: where reg represents an even number in the 

range 0-254 
©RRp: where p = 0,2,..., 14 
reg (Rn): where reg represents a number in the 

range 0-255 and n = 0-15 
addrs (RRp): where addrs represents a number in 

the range -128 to +127 and p = 0,2,..., 14 
addrs (RRp): where addrs "represents a number in 

the rar>ge 0-65,535 and p = 0,2,..., 14 
addrs: where addrs represents a number in the 

range 0-65,535 
addrs: where addrs represents a number in the 

range +127,-128 that is an offset relative to 

the address of the next instruction 
#data: where data is a number between and 255 
#data: where data is a number between and 

65,535 
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5. 4.1 Notational Shorthand 

Operands and status flags are represented by a 
notational shorthand in the detailed instruction 
descriptions of section 5.5.2. The notation for 
operands (condition codes and addressing modes) 
and the actual operands they represent are shown 
in Table 5-3. 



Additional Symbols Used: 
Symbol Meaning 



indicates that the source data is added to the 
destination data and the result is stored in the 
destination location. The notation "addr (n)" is 
used to refer to bit "n" of a given location. For 
example, / 

dst (7) 

refers to bit 7 of the destination operand. 

5.4.2 Flag Settings 

Notation for the flags is shown below. 



dst 


Destination operand 








src 


Source operand 


Flag 


Meaning 




® 


Indirect Register address prefix 




- 




SP 


Stack Pointer (R216 and R217) 


C 


Carry flag 




PC 


Program Counter 


Z 


Zero flag 




IP 


Instruction Pointer (R218 and 


s 


Sign flag 






R219) 


V 


Overflow flag 




FLAGS 


Flag register (R213) 


D 


Decimal-Adjust flag 




RPO 


Register Pointer (R214) 


H 


Half-Carry flag 




RP1 


Register Pointer 1 (R215) 





Cleared to 




IMR 


Interrupt Mask register (R221) 


1 


Set to 1 




# 


Immediate operand or Register 


* 


Set or Cleared according to 


operation 




address prefix 


- 


Unaffected 




% 


Hexadecimal number prefix 


X 


Undefined 




OPC 


Opcode 









Assignment of a value is indicated by the symbol 
"< — "; for example, 

dst <— dst + src 



Figure 5-2 provides a quick reference guide to the 
commands. 



530 



Instruction Set 



SUPER8 OPCODE MAP 

1 2 



Lower Nibble (Hex) 
6 7 8 



6 


6 


6 


6 


10 


10 


10 


10 


6 


6 


12/10 


12/10 


6 


12/10 


6 


14 


DEC 


DEC 


ADD 


ADD 


ADD 


ADD 


ADD 


BOR* 


LD 


LD 


DJNZ 


JR 


LD 


JP 


INC 


NEXT 


Ri 


iRi 


ri.r2 


ri.lr2 


R2.R1 


IR2.R1 


Rl.lM 


ro-Rb 


ri,R2 


r2.Rl 


ri.RA 


cc.RA 


riJM 


cc.DA 


n 




6 


6 


6 


6 


10 


10 


10 


10 






























20 


RLC 


RLC 


ADC 


ADC 


ADC 


ADC 


ADC 


BCP 






























ENTER 


Ri 


IRi 


ri.r2 


ri.lr2 


R2.R1 


iR^.Ri 


RlJM 


ri,b,R2 
































6 


6 


6 


6 


10 


10 


10 


10 


22 


INC 


INC 


SUB 


SUB 


SUB 


SUB 


SUB 


BXOR* 






























EXIT 


Ri 


IRi 


ri.r2 


n-ir2 


R2.R1 


lR2>Ri 


RlJM 


ro-Rb 
































10 




6 


6 


10 


10 


10 




6 


jp 


NOTE 
C 


SBC 


SBC 


SBC 


SBC 


SBC 


NOTE 
A 






























WFI 


IRRl 


ri.r2 


ri.lr2 


R2,Ri 


IR2.R1 


Rl,IM 
































6 


6 


6 


6 


10 


10 


10 


10 


6 


DA 


DA 


OR 


OR 


OR 


OR 


OR 


LDB* 






























SBO 


Ri 


IRi 


ri.r2 


ri.lr2 


R2.R1 


IR2.R1 


RlJM 


ro-Rb 
































10 


10 


6 


6 


10 


10 


10 


8 


6 


POP 


POP 


AND 


AND 


AND 


AND 


AND 


BITC 






























SBI 


Ri 


IRi 


ri-r2 


ri,lr2 


R2.R1 


IR2.R1 


RlJM 


ri,b 
































6 


6 


6 


6 


10 


10 


10 


10 




COM 


COM 


TCM 


TCM 


TCM 


TCM 


TCM 


BAND* 
































Ri 


IRi 


n.r2 


ri.lr2 


R2.R1 


IR2.R1 


RlJM 


ro-Rb 
































10/12 


12/14 


6 


6 


10 


10 


10 ■ 


NOTE 

B 




PUSH 


PUSH 


TM 


TM 


TM 


TM 


TM 
































R2 


IR2 


ri.r2 


ri.lr2 


R2.R1 


IR2.R1 


RlJM 
































10 


10 


10 


10 


24 


24 


24 


10 


6 


DECW 


DECW 


PUSHUD 


PUSHUi 


MULT 


MULT 


MULT 


LD 






























Dl 


RRl 


IRi 


IRi,R2 


IR1.R2 


R2.RR1 


IR2.RR1 


IM,RRi 


ri,x,r2 
































6 


6 


10 


10 


28/12 


28/12 


28/12 


10 


6 


RL 


RL 


POPUD 


POPUI 


DIV 


DIV 


DIV 


LD 






























El 


Ri 


IRi 


IR2.R1 


IR2.R1 


R2,RRi 


IR2,RRi 


IM.RRi 


r2.x,ri 
































10 


10 


6 


6 


10 


10 


10 


NOTE 
D 


14 


INCW 


INCW 


CP 


CP 


CP 


CP 


CP 






























RET 


RRl 


IRi 


ri.r2 


ri,lr2 


R2.R1 


IR2,Ri 


RlJM 
































6 


6 


- 6 


6 


10 


10 


10 


NOTE 
E 


16/6 


CLR 


CLR 


XOR 


XOR 


XOR 


XOR 


XOR 






























IRET 


Ri 


IRi 


'•1.^2 


ri,lr2 


R2.R1 


lR2,Ri 


RlJM 


















> 














6 


6 


16/18 


12 


10 


10 


12 


6 


6 


RRC 


RRC 


CPIJE 


LDC* 


LDW 


LDW 


LDW 


LD 






























RCF 


Ri 


IRi 


lr,r2,RA 


ri,lrr2 


RR2,RRi 


IR2,RRi 


RRlJML 


ri.lr2 
































6 


6 


16/18 


12 


20 




10 


6 


6 


SRA 


SRA 


CPIJNE 


LDC* 


CALL 




LD 


LD 






























SCF 


Ri 


IRi 


lri,r2,RA 


r2,lrri 


IA1 




IR1JM. 


Iri,r2 
































6 


6 


16 


16 


10 


10 


10 


18 


6 


RR 


RR 


LDCD* 


LDCI* 


LD 


LD 


LD 


LDC* 






























CCF 


Ri 


IRi 


ri,lrr2 


ri,lrr2 


R2.R1 


IR2-R1 


R-lJM 


riJrr2,xs 
































8 


8 


16 


16 


18 


10 


18 


18 


6 


SWAP 


SWAP 


LDCPD* 


LDCPI* 


CALL 


LD 


CALL 


LDC* 






























NOP 


Ri 


IRi 


r2,lrri 


r2.lrri 


IRRl 


R2.IR1 


DAi 


r2Jrri,xs 


y 


f 


\ 


f 


\ 


f 


1 


r 


\ 


r 


\ 


r 


y 


f 





16/18 
BTJRF 

r2,b,RA 


16/18 
BTJRT 

r2,b,RA 



NOTEB 


8 
BITR 

ri.b 


8 
BITS 

ri,b 








20 
LDC* 

riJrr2,xL 


20 
LDC* 

ri,DA2 


NOTEE 



NOTEC 



6 
SRP 

IM 


6 
SRPO 

IM 


6 
SRP1 

IM 



20 
LDC* 

r2Jrr2,xL 


20 
LDC* 

r2,DAi 



Legend: 

r = 4-bit address 
R = 8-bit address 
b = bit number 
Ri or ri = dst address 
R2 or r2 = src address 



* Examples: 

BOR ro-R2 

isB0Rri,b,R2 

orBORr2,b,Ri 
LDCriJrr2 

isLDCr-tJrr2 = program 

orLDE riJrr2 = data 



Sequence: 

Opcode, first, second, third operands 

NOTE: The blank areas are not defined. 



Figure 5-2. Supers Opcode Map 
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5.5 

Instruction 
Descriptions 
and Formats 



ADC 

Add With Carry 



ADC dst,src 
Operation: 



Flags: 



dst -«— dst + src + c 

The source operand, along with the setting of the Carry flag, is added to the destination 
operand and the sum is stored in the destination. The contents of the source are unaffect- 
ed. Twos-complement addition is performed. In multiple precision arithmetic, this instruc- 
tion permits the carry from the addition of low-order operands to be carried into the 
addition of high-order operands, 

C: Set if there is a carry from the most significant bit of the result; cleared otherwise. 

Z; Set if the result is 0; cleared otherwise, 

V: Set if arithmetic overflow occurs, that is, if both operands are of the sam-^ sinn and 

the result is of the opposite sign; cleared otherwise, 
S: Set if the result is negative; cleared otherwise, 
Os Always cleared 
H: Set if there is a carry from the most significant bit of the low-order four bits of the 

result; cleared otherwise. 



Instruction 
Format : 



Opcode Addressing Mode 
Cycles (Hex) dst src 



Opcode dst src 



Opcode 



6 


12 
13 


r 

r 


r 
Ir 


10 


14 
15* 


R 
R 


R 
IR 



Opcode 



Id 



16 



IM 



*This format is used in the example. 



Example: 



If the register named SUM contains 5o16, the Carry flag is set to 1, working register 10 
contains ?o20 (32 decimal), and register 32 contains %10, the statement 

ADC SUM, IRIO 

leaves the value 5b27 in register SUM. 
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AND 

Logical 



AND dstysrc 

Operation; dst -♦- dst AND src 



Flags: 


G: 




Zs 




V: 




S; 




H: 




D: 


Instruction 




Format: 





The source operand is logically ANDed with the destination operand. The result is stored in 
the destination. The AND operation results in a 1 bit being stored whenever the correspond- 
ing bits in the two operands are both Is; otherwise a bit is stored. The contents of the 
source are unaffected. 

Unaffected 

Set if the result is 0; cleared otherwise. 

Always cleared to 0. 

Set if the result bit 7 is set; cleared otherwise. \ 

Unaffected 

Unaffected 



Opcode Addressing Mode 
Cycles (Hex) dst src 



Opcode dst src 



Opcode 



6 


52 


r 


r 




53 


r 


Ir 


10 


54 


R 


R 




55 


R 


IR 



Opcode 



dst 



10 56* R IM 
*This format is used in the example. 



Example : 



If the source operand is the immediate value ?o7B (01111011) and the register named TARGET 
contains %C3 (11000011), the statement 

AND TARGET, /i%7B 

leaves the value ?o43 (01000011) in register TARGET. 
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BAND 

Bit And 



BAND dst,src,b 
BAND dst,b,src 

Operation: 



Example : 



dst(O) -*- dst(O) AND src(b) 

or 
dst(b) -•— dst(b AND src(O) 

The specified bit of the source (or the destination) is logically ANDed with bit of the 
destination (or source). The resultant bit is stored in the specified bit of the 
destination. No other bits of the destination are affected. The source is unaffected. 



Flags: C: Unaffected 

Z: Set if the result is 0; cleared otherwise. 

V: Undefined 

S: 

H: Unaffected 

D: Unaffected 


Instruction 
Fornat : 














Opcode 
Cycles (Hex) 

10 67* 

10 67 
*This format is used 


Addressing Mode 
dst src 




Opcode 




dst 


,b 







src 




^Q % 




















Opcode 




src 


b 


1 




dst 




Rb ro 
















in the example. 



If the register named BYTE contains 5Ib73 (01110011) and working register 3 contains SOI, the 
statement 

BAND R3,BYTE,//7 

leaves the value %00 in working register 3. 
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BCP 

Bit Compare 



BCP dst,src,b 
Operation: 



dst(O) - src(b) 

The specified bit of the source is compared to (subtracted from) bit of the destination. 
The Zero flag is set if the bits are the same; otherwise it is cleared. The contents of 
both operands are unaffected by the comparison. 



Flags: 


C: 


Unaffected 






Z: 


Set if the two bits are the same; 


cleared otherwise. 




V: 


Undefined 






S: 









H: 


Unaffected 






D: 


Unaffected 




Instruction 








Format: 









Opcode 



dst 


b 






Cycles 

10 



Opcode Addressing Mode 
(Hex) dst src 



17 



ro 



Rb 



Example: 



If working register 3 contains 5o01 and register 64 (?o40) contains %Ff , the statement 

BCP R3,64,#0 
sets the Zero flag bit in Flag register R213. 



BITC 

Bit Complement 



BITC dst,b 
Operation: 

Flags: 



dst(b) -*-- NOT dst(b) 

This instruction complements the specified bit within the destination without affecting any 
other bits in the destination. 

C: Unaffected 

Z: Set if the result is 0; cleared otherwise, 

V: Undefined 

S: 

H: Unaffected 

D: Unaffected 



Instruction 
Format: 



Opcode 



dst 


b 






Cycles 

8 



Opcode 
(Hex) 

57 



Addressing Mode 
dst 

^b 



Example: 



If working register 3 contains ?oFF, the statement 

BITC R3,#7 . 
leaves the value 5o7F in that register. 



535 



BITR 

Bit Reset 



BITR dst,b 
Operation: 

Flags: 



dst(b) -«— 

This instruction clears the specified bit within the destination without affecting any other 
bits in the destination. 

No flags affected 



Instruction 
Forniat : 



Opcode 



dst 


b 






Cycles 

8 



Opcode Addressing Mode 
(Hex) dst 



77 



Tb 



Example: 



If working register 3 contains ?o80, the statement 

BITR R3,#7 
leaves the value SOO in that register. 



BITS 

Bit Set 



BITS dst,b 
Operation: 

Flags: 



dst(b) ^- 1 

This instruction sets the specified bit within the destination without affecting any other 
bits in the destination. 

No flags affected 



Instruction 
Fornat : 



Opcode 



dst 


b 


1 



Cycles 

8 



^ Opcode Addressing Mode 
(Hex) dst 



77 



Tb 



Example: 



If working register 3 contains %00, the statement 

BITS R3,//7 
leaves the value ?o80 in that register. 
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BOR 

Bit OR 



BOR dst,src,b 
BOR dst,b,src 

Dperation: 



dst(O) -•-- dst(O) OR src(b) 

or 
dst(b) ^- dst(b) OR src(O) 

The specified bit of the source (or the destination) is logically ORed with bit of the 
destination (or the source). The resultant bit is stored in the specified bit of the 
destination. No other bits of i the destination are affected. The source is unaffected. 



Flags: 


C: 


Unaffected 






Z: 


Set, if the result is 0; 


cleared otherwise 




V: 


Undefined 






S: 









H: 


Unaffected 






D: 


Unaffected 




Instruction 








Forniat: 









Opcode Addressing Mode 
Cycles (Hex) dst src 



Opcode 



dst 



Opcode 



src 


b 


1 



10 



10 



07 
07* 



ro 
Rb 



Rb 



ro 



*This format is used in the example. 



Example: 



If register 32 (?o20) contains SoOF and working register 3 contains ?o01 , the statement 

BOR 32,#7,R3 
leaves the value %8F in register 32. 
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BTJRF 

Bit Test and Jump Relative on False 



BT3RF dst,src,b 

Operation: If src(b) is a 0, PC -*-- PC + dst 

The specified bit within the source operand is tested. If it is a 0, the relative address 
is added to the Program Counter and control passes to the statement whose address is now in 
the PC; otherwise the instruction following the BTJRF instruction is executed. 



Flags: No flags affected 


Instruction 
Format : 














Cycles 

16/18* 
* 18 if 


Opcode 
(Hex) 

37 
jump taken, 


Addressing Mode 
dst src 




Opcode 




src 


b 







dst 


RA Fb 


' 














16 if not 



Example: 



If working register 6 contains ?o7F,the statement 

BTJRF SKIP,R6,#7 

causes the Program Counter to jump to the memory location pointed to by SKIP, 
location must be within the allowed range of +127,-128. 



The memory 



BTJRT 

Bit Test and Jump Relative on True 



BTJRT dst, src, b 

Operation; If src(b) is a 1, PC -*•- PC + dst 

The specified bit within the source operand is tested. If it is a 1, the relative address 
is added to the Program Counter and control passes to the statement whose address is now in 
the PC; otherwise the instruction following the BTJRT instruction is executed. 



Flags: 



No flags affected 



Instruction 
Format : 



Opcode 



src 


b 


1 



Opcode Addressing Mode 

Cycles (Hex) dst src 

16/18* 37 RA Tb 

* 18 if jump taken, 16 if not 



Example: 



If working register 6 contains ?o80, the statement 

- BTJRT $+8,R6,#7 
causes the next five bytes in memory to be skipped. 



Note: 



The $ refers to the address of the first byte of the instruction currently being executed. 
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BXOR 

BitXOR 



BXOR cist,src,b 
BXOR dst,b,src 

Opieration: 



Example: 



(dst(O) 

or 
dst(b) 



dst(O) XOR src(b) 
dst(b) XOR src(O) 



The specified bit of the source (or the destination) is logically EXCLUSIVE ORed with bit 
of the destination (or source). The resultant bit is stored in the specified bit of the 
destination. No other bits of the destination are affected. The source is unaffected. 



Flags: C: 


Unaffected 










Z: 


Set if the result is 0; cleared otherwise. 










V: 


Undefined 










S: 













H: 


Unaffected 










D: 


Unaffected 










Instruction 














Format : 








Opcode 


Addressing Mode 


















Cyclea 

10 

10 
*This 


(Hex) 

27* 

27 
format is used 


dst 

ro 
Rb 

in the 


src 




Opcode 




dst 


b 







src 




Rb 






















Opcode 




src 


b 


1 




dst 




ro 


















example. 



If working register 6 contains ?oFF and working register 7 contains %F0, the statement 

BXOR R6,R7,M ' 

leavefe the value ?oFE in working register 6. 
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CALL 

Call Procedure 



CALL dst 
Operation: 



Flags: 



SP ^- sp , 1 

asp ^- PCL 

SP ^- SP - 1 

iSP ^- PCH 
PC ^- dst 

The current contents of the Program Counter are pushed onto the top of the stack. The 
Program Counter value used is the address of the first instruction following the CALL 
instruction. The specified destination address is then loaded into the Program Counter and 
points to the first instruction of a procedure. 

At the end of the procedure the Return (RET) instruction can be used to return to the 
original program flow. RET pops the top of the stack back into the Program Counter. 

No flags affected 



Instruction 
Format : 



Opcode 



Opcode 



Opcode 



Opcode 
Cycles (Hex) 



dst 



dst 



18 



18 



20 



F6 



F4 



04 



Addressing Hode 
dst 

DA 



IRR 



lA. 



Examples: 



(1) If the contents of the Program Counter are ?61A47 and the contents of the Stack Pointer 
(control registers 216-217) are %3002, the statement 

CALL 5«3521 

causes the Stack Pointer to be decremented to Sb3000, %1A4A (the address following the 
instruction) to be stored in external data memory locations S»3000 and ?o3001 (5o4A in ?o30001 , 
?o1A in %3000), and the Program Counter to be loaded with %3521 . The Program Counter now 
points to the address of the first statement in the procedure to be executed. 

(2) If the contents of the Program Counter and Stack Pointer are the same as in Example 1, 
working register 6 contains 9o35, and working register 7 contains So21, the statement 

CALL iiRR6 

produces the same result as Example 1 except that %49 is stored in external data memory 
location %3000. 

(3) If the contents of the Program Counter and Stack Pointer are the same^as in Example 1, 
address %0040 contains ?o35, and address ?o0041 contains ?o21 , the jstatement 

CALL ri40 

produces the same result as Example 2. 
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ADD 

Add 



ADO dst,src 
Operation: 



Flags: 



dst '•— dst + src 

The source operand is added to the destination operand and the sum is stored in the 
destination. The contents of the source are unaffected. Twos-complement addition is 
performed. 

C: Set if there was a carry from the most significant bit of the result; cleared otherwise. 

Z: Set if the result is 0; cleared otherwise. 

V: Set if arithmetic overflow occurred, that is, if both operands were of the same sign and 

the result is of the opposite sign; cleared otherwise, 

S: Set if the result is negative; cleared otherwise. 

H: Set if a carry from the low-order nibble occurred. 

D: Always cleared to 0. 



Instruction 
Format : 



Opcode 




dst 


src 














Opcode 




src 




dst 












Opcode 




dst 




src 



Opcode Addressing Mode 
Cycles (Hex) dst src 



6 


02 


r 


r 




03 


r 


Ir 


10 


04* 


R 


R 




05 


R 


IR 



10 



06 



IM 



*This format is used in the example. 



Example: 



If the register named SUM contains ?o44 and the register named AUGEND contains ?i1 1 , the 
statement 

ADD SUM, AUGEND 

leaves the value %55 in Register SUM. 
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CCF 

Complement Carry Flag 



CCF 
Operation : 

Flags: 



C ■^- NOT C 

The Carry flag is complemented; if C = 1, it is changed to C = 0, and vice-versa. 

C: Complemented 

No other flags affected 



Instruction 
Fornat : 



Opcode 



Opcode 
Cycles (Hex) 

6 EF 



Exanple : 



If the Carry flag contains a 0, the statement 

CCF 
changes the to 1 . 



CLR 

Clear 



CLR dst 
Operation: 



dst -*-- 

The destination location is cleared to 0. 



Flags: 



No flags affected 



Instruction 
Fornat : 



Opcode 



dst 



Opcode 
Cycles (Hex) 

6 BO* 
B1 



Addressing Mode 
dst 

R 
IR 



This format is used in the example. 



Example: 



If working register 6 contains ?oAF, the statement 

CLR R6 
leaves the value in that register. 
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COM 

Complement 



COM dst 
Operation: 

Flags: 



dst -«— NOT dst 

The contents of the destination location are complemented (ones complement); all 1 bits are 
changed to 0, and vice-versa, 

C: Unaffected 

Z: Set if the result is 0; cleared otherwise, 

V: Always reset to 

S: Set if the result bit 7 is set; cleared otherwise. 

H: Unaffected 

D: Unaffected 



Instruction 
Fornat : 



Opcode Addressing Hode 
Cycles (Hex) dst 



Opcode 



60* 
61 



R 
IR 



*This format is used in the example. 



Example: 



If working register 8 contains %24 (00100100), the statement 

COM R8 
leaves the value SOB (11011011) in that register. 
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CP 

Compare 



CP dst,src 
Operation: 



Example : 



dst - src 

The source operand is compared to (subtracted from) the destination operand, and the 
appropriate flags are set accordingly. The contents of both operands are unaffected by the 
comparison. 



Flags: C: 
Z: 
V: 
S: 
H: 
D: 


Set if a "borrow" occurred (src > dst); cleared otherwise. 

Set if the result is 0; cleared otherwise. 

Set if arithmetic overflow occurred, cleared otherwise. 

Set if the result is negative; cleared otherwise. 

Unaffected 

Unaffected 








Instruction 
Format : 














Opcode 
Cycles (Hex) 

6 A2 
A3 

10 A4 
A5* 

10 A6 

*This format is used 


Addres 
dst 

r 
r 

R 
R 

R 

in the 


tsing Mode 
src 




Opcode 




dst 


src 




r 
Ir 






















Opcode 




src 




dst 




R' 
IR 






















Opcode 




dst 




src 




IM 


















example. 



If the register named TEST contains ?o63, working register contains %30 (48 decimal), and 
register 48 contains Sd63, the statement 

CP TEST, iRO 

sets (only) the Z flag. If this statement is followed by "JP EQ, true__routine," the jump 
will be taken. 
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DA 

Decimal Adjust 



DA dst 
Operation: 



dst <*- DA dst 

The destination operand is adjusted to form two A-bit BCD digits following an addition or 
subtraction operation. For addition (ADD, ADC) or subtraction (SUB, SBC), the following 
table indicates the operation performed: 





Carry 


Bits 4-7 


H Flag 


Bits 0-3 


Number Added 


Carry 


Instruction 


Before OA 


Value (Hex) 


Before DA 


Value (Hex) 


To 


Byte 


After DA 







0-9 





0-9 




00 










0-8 





A-F 




06 










0-9 


1 


0-3 




06 





ADD 





A-F 





0-9 




60 


1 


ADC 





9-F 





A-F 




66 


1 







A-F 


1 


0-3 




66 


1 




1 


0-2 





0-9 




60 


1 




1 

1 


0-2 

0-3 




1 


A-F 

0-3 




66 

66 


1 

1 







0-9 





0-9 


00 


= -00 





SUB 





0-8 


1 


6-F 


FA 


= -06 





SBC 


1 


7-F 





0-9 


AO 


= -60 


1 




1 


6-F 


1 


6-F 


9A 


= -66 


1 



The operation is undefined if the destination operand was not the result of a valid addition 
or subtraction of BCD digits. 



Flags: 



C; Set if there was a carry from the most significant bit; cleared otherwise (see table 

above) . 

Z: Set if the result is 0; cleared otherwise. 

V: Undefined 

S: Set if the result bit 7 is set; cleared otherwise. 

H: Unaffected 

Dz Unaffected 



Instruction 
Format : 



Opcode 



Cycles 

6 



Opcode Addressing Mode 
(Hex) dst 



40* 
41 



R 
IR 



*This format is used in the example. 



Example: 



If working register RO contains %^5 and working register R1 contains ?o27, the statements 

ADD R1, RO 
DAB R1 

leave ?o42 in working register R1. 

If addition is performed using the BCD values 15 and 27, the result should be 42. The sum 
is incorrect, however, when the binary representations are added in the destination location 
using standard binary arithmetic. 

0001 0101 
+ 0010 0111 



0011 1100 = ?i3C 

The DA statement adjusts this result so that the correct BCD representation is obtained. 

0011 1100 
+ 0000 0110 



0100 0010 = 42 
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CPUE 

Compare Increment and Jump on Equal 



CPI3E dst,src,RA 

Operation: If dst - src = zero, PC -4— PC + RA 
Ir -*-- Ir + 1 

The source operand is compared to (subtracted from) the destination operand. If the result 
is, 0, the relative address is added to the Program Counter and control passes to the 
statement whose address is now in the Program Counter; otherwise the instruction following 
the CPUE instruction is executed. In either case the source pointer is incremented by one 
before the next instruction. 



Flags: 



No flags affected 



Instruction 
Format : 



Opcode 



src 


dst 



RA 



Opcode Addressing Mode 

Cycles (Hex) dst src 

16/18* C2 r Ir 

* 18 if jump taken, 16 if not 



Example: 



If working register 3 contains %AA, working register 5 contains %10, and register %^0 
contains ?oAA, the statement 

CPUE R3,iR5,$ 

puts the value ?o11 in working register 5 and then executes the same instruction again. 



CPIJNE 

Compare Increment and Jump on Non Equal 



CPI3NE dst, src, RA 
Operation: 



Flags: 



If dst - src t zero, PC ^- PC + RA 
Ir ^- Ir + 1 

The source operand is compared to (subtracted from) the destination operand. If the result 
is not 0, the relative address is added to the Program Counter and control passes to the 
statement whose address is now in the Program Counter; otherwise the instruction following 
the CPIJNE instruction is executed. In either case, the. source pointer is incremented by 
one before the next instruction. 

No flags affected 



Instruction 
Format : 



Opcode 



src 


dst 



Opcode Addressing Mode 
Cycles (Hex) dst src 

16/18* D2 r Ir 

* 18 if jump taken, 16 if not 



Example: 



If working register 3 contains ?oAA, working register 5 contains ?o10, and register %^Q 
contains SbAA, the statement 

CPUNE R3,iiR5,$ 

puts the value %11 in working register 5 and then executes the next instruction following 
this instruction. 



Note: 



The $ refers to the address of the first byte of the instruction currently being executed. 
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DEC 

Decrement 



DEC dst 
Operation: 



dst -*-- dst - 1 

The contents of the destination operand are decremented by one. 



Flags: 


C: 




Z: 




V: 




S: 




H: 




D: 


Instruction 




Fotnat : 





Unaffected 

Set if the result is 0; cleared otherwise. 

Set if arithmetic overflow occurred; cleared otherwise. 

Set if result is negative; cleared otherwise. 

Unaffected 

Unaffected 



Opcode 



dst 



Cycles 

6 



Opcode Addressing Node 
(Hex) dst 



00* 
01 



R 
IR 



This format is used in the example. 



Example: 



If working register 10 contains ?o2A, the statement 

DEC RIO 
leaves the value %19 in that register. 
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DECW 

Decrement Word 



DECW dst 
Operation: 

Flags: 



dst ^- dst - 1 

The contents of the destination location (which must be an even address) and the operand 
following that location are treated as a single 16-bit value which is decremented by one. 

C: Unaffected 

Z: Set if the result is 0; cleared otherwise. 

V: Set if arithmetic overflow occurred; cleared otherwise, 

S: Set if the result is negative; cleared otherwise. 

H: Unaffected 

D: Unaffected 



Instruction 
Format : 



N 



Opcode 



Cycles 

10 



Opcode 
(Hex) 

80' 
81* 



Addressing Mode 
dst 

RR 
IR 



This format is used in the example. 



Example: 



If working register contains %30 (48 decimal) and registers 48-49 contain the value ?oFAF3, 
the statement 

DECW iRO 

leaves the value ?oFAF2 in registers 48 and 49. 



Dl 

Disable Interrupts 



DI 
Operation: 



Flags: 



SMR (0) ^- 

Bit of control register 222 (the System Mode register) is cleared to 0. All interrupts 
are disabled; they can still set their respective interrupt status latches, but the CPU will 
not directly service them. 

No flags affected 



Instruction 
Format : 



Opcode 



Cycles 

6 



Opcode 
(Hex) 



Example: 



If control register 222 contains %01 , that is, interrupts are enabled, the statement 

DI 
sets control register 222 to ?oOO, disabling all interrupts. 
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Divide (Unsigned) 



DIV clst.,src 
Operation: 



Flags: 



dst "f src 

dst (UPPER) -^- REMAINDER 
dst CLOWER) -^- QUOTIENT 

The destination operand (16 bits) is divided by the source operand (8 bits). The quotient 
(8 bits) is stored in the lower half of the destination. The remainder (8 bits) is stored 
in the upper half of the destination. When the quotient is >2^, the numbers stored in the 
upper and lower halves of the destination for quotient and remainder are incorrect. Both 
operands are treated as unsigned integers. 

C: Set if V is set and quotient is between 2^ and 2^-1; cleared otherwise. 

Z: Set if divisor or quotient = 0; cleared otherwise. 

V: Set if quotient is > 2^ or divisor = 0; cleared otherwise. 

S: Set if MSB of quotient = 1; cleared otherwise. 

H: Unaffected 

D: Unaffected 



Instruction 
Format : 



Opcode 



dst 



Cycles 



Opcode 
(Hex) 



Addressing Mode 
dst src 



28/12* 94* 
29/12* 95 
28/12* 96 



RR 
RR 
RR 



R 
IR 

IM 



12 if divide by zero is attempted 
This format is used in the example 



Example : 



If working register pair 6-7 (dividend) contains ?o10 in register 6 and ?o03 in register 7, 
and working register 4 (divisor) contains ?o40, the statement 

DIV RR6,R4 

leaves the value ?o40 in working register 7 (quotient) and the value ?o03 in working register 
6 (remainder). 
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djn;z 

Decrement and Jump if Nonzero 



D3NZ r,dst 
Operation: 



Flags: 



r -*-- r -1 
If r / 0, PC 



PC + dst 



The working register being used as a counter is decremented. If the contents of the 
register are not after decrementing, the relative address is addecl to the Program Counter 
and control passes to the statement whose address is now in the Program Counter. The range 
of the relative address is +127 to -128, and the original value of the Program Counter is 
taken to be the address of thfe instruction byte following the D3NZ statement. When the 
working register counter reaches zero, control falls through to the statement following the 
D3NZ statement. 

No flags affected 



Instruction 
Format : 



r 


Opcode 



Cycles ; 

12 if jump taken 

10 if jump not taken 



Opcode 
(Hex) 

rA 

r = to r 



Addressing Mode 
dst 

RA 



Example: 



D3NZ is typically used to control a "loop" of instructions. In this example, 12 bytes are 
moved from one buffer area in the register file to another. The steps involved are: 

o Load 12 into the counter (working register 6) 
o Set up the loop to perform the moves 
o End the loop with DONZ 



LOOP: 



LD R6,#12 
LD R9,0LDBUF (R6) 
LD NEWBUF (R6),R9 
D3NZ R 6, LOOP 



!Load Counter! 

IMove one byte to! 

!New location! 

! Decrement and ! 

!Loop until counter = 0! 



Note: 



The working register being used as a counter must be one of the registers 00-CF. Using one 
of the I/O ports, control or peripheral registers will have undefined results. 
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El 

Enable Interrupts 



EI 
Operation: 



SMR (0) <•-- 1 

Bit of control register 220 (the System Mode register) is set to 1. This allows any 
interrupts to be serviced when they occur (assuming they have highest priority) or, if their 
respective interrupt status latch was previously enabled by its interrupt, then its 
interrupt can also be serviced. 



Flags: 



No flags affected 



Instruction 
Fornat : 



Opcode 



Cycles 

6 



Opcode 
(Hex) 



Example : 



If control register 222 contains ?oOO, (i.e., interrupts are disabled), the statement 
EI y 

sets control register 222 to ?o01 , enabling all interrupts. 



ENTER 

Enter 



ENTER 
Operation: 



Flags: 



SP ^- SP - 2 

isp -•.- IP ' 

IP ^- PC 
PC -^- IIP 
IP ^- IP + 2 

This instruction is useful for the implementation of threaded-code languages. The contents 
of the Instruction Pointer are pushed onto the stack. The value in the Program Counter is 
then transferred to the Instruction Pointer. The program memory word pointed to by the 
Instruction Pointer is loaded into the Program Counter. The Instruction Pointer is then 
incremented by two. 

No flags affected 



Instruction 
Format : 



Opcode 



Cycles 

20 



Opcode 
(Hex) 
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ENTER 

Enter (Continued) 



Exaaple: 



Before 



Address 



"^ After 



Address 




40 


ENTER 


41 


Addr H 


42 


Addr L 


»-43 


Addr H 


►110 


Routine 



Data 



Memory 



EXIT 

Exit 



EXIT 




Operation: 


IP ^- iSP 
SP ^. SP ^. 2 

PC -^- iiP 

IP ^- IP + 2 



Flags: 



This instruction is useful for the implementation of threaded-code languages. The stack is 
POPed and the Instruction Pointer is loaded. The program memory word pointed to by the 
Instruction Pointer is loaded into the Program Counter. The Instruction Pointer is then 
incremented by two. 

No flags affected 



Instruction 
Fornat : 



Opcode 



Cycles 

22 



Opcode 
(Hex) 

2F 
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EXIT 

Exit (Continued) 



Example: 



Note: 



Before 



After 




INC 

Increment 



The examples for ENTER, EXIT, and NEXT illustrate how these instructions could actually be 
used together in a program. 



INC dst 
Operation: 



dst ^- dst + 1 

The contents of the destination operand are incremented by one. 



riags: 



C: Unaffected 

Z: Set if the result is 0; cleared otherwise, 

V: Set if arithmetic overflow occurred; cleared otherwise, 

S: Set if the result is negative; cleared otherwise. 

H: Unaffected 

D: Unaffected 



Instruction 
Foraat : 



dst Opcode 



Opcode 



Cycles 


Opcode 
(Hex) 




Addressing Mode 
dst 


6 


rE* 
r = 


to 


F 


r 


6 


20 
21 






R 
IR 



*This format is used in the example. 



Example: 



If working register 10 contains ?o2A, the statement 

INC RIO 
leaves the value ?o2B in that register. 
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INCW 

Increment Word 



INCW dst 
Operation: 

Flags: 



dst ■^- dst + 1 

The contents of the destination (which must be an even address) and the byte following that 
location are treated as a single^^ 16-bit valge which is incremented by one. 

C: Unaffected 

Z: Set if the result is 0; cleared otherwise. 

V: Set if arithmetic overflow occurred; cleared otherwise. 

S: Set if the result is negative; cleared otherwise. 

H: Unaffected 

D: Unaffected 



Instruction 
Format : 



Opcode Addressing Mode 
Cycles (Hex) dst 



Opcode 



dst 



10 



AO* 
A1 



RR 
IR 



This format is used in the example. 



Example: 



If working register pair 0-1 contains the value ?oFAF3, the statement 

INCW RRO N 

leaves the value ?oFAF4 in working register pair 0-1 . 
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IRET 

Interrupt Return 



Operation: 



IRCT (Normal) 

Flags -fr- ISP 
SP ^_ SP + 1 
PC ^- iSP 
SP ^- SP + 2 
SYM(O) -«-- 1 



IRET (Fast) 

PC ^^ IP 
Flag -*-- Flag' 
FIS ^- 



Flags: 



This instruction is issued at the end of an interrupt service routine. It restores the Flag 
register and the Program Counter. It also reenables global interrupts. 

Normal IRET is executed only if the Fast Interrupt Status bit (FiS, bit 1 of the Flags 
register R213) is cleared. Fast IRET is executed if FIS is set, indicating that a fast 
interrupt is being serviced. 

All flags are restored to original settings (before interrupt occurred). 



Instruction 
Forinat : 



IRET (Nornal) 



Opcode 



IRET (Fast) 



Cycles 


Opcode 
(Hex) 


16 


BF 


Cycles 


Opcode 
(Hex) 



Opcode 



6* BF 
*This format is used in the example. 



Example : 



In the figure below, the Instruction Pointer is initially loaded with 5o100 in the main 
program before interrupts are enabled. When an interrupt occurs, the Program Counter and 
Instruction Pointer are swapped. This causes the Program Counter to jump to address ?o100 
and the Instruction Pointer to keep the return address. The last instruction in the service 
routine normally is a Jump to IRET at address %FF. This causes the Instruction Pointer to 
be loaded with ?o10Q "again", and the Program Counter to jump back to the main program. Now 
the next interrupt can occur and the Instruction Pointer is still correct at ?o100. 



FF 


IRET 


100 


Interrupt 

Service 

Routine 


FFFF 


3P% to FF 



Note: 



For the Fast Interrupt example above, if the last instruction is not a 3ump to IRET, then 

care must be taken with the order of the last two instructions. The instruction IRET cannot 

be immediately preceded by a clear of interrupt status (such as a reset of the Interrupt 
Pending register). 
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JP 

Jump 



3P cCjdst 
OP dst 

Operaticxi: 



Flags: 



If cc is true, PC -*•- dst 

The conditional 3ump transfers program control to the destination address if the condition 
specified by "cc" is true; otherwise, the instruction following the 3P instruction is 
executed. See section 5.3 for a list of condition codes. 

The unconditional 3ump simply replaces the contents of the Program Counter with the contents 
of the specified register pair. Control then passes to the statement addressed by the 
Program Counter. 

No flags affected 



Instruction 
Foriiat : 



Conditional 



cc 


Opcode 



dst 



Cycles 

10/12* 



Opcode 
(Hex) 



Addressing Mode 
dst 



ccD** 

cc = to F 



DA 



Unconditional 



Opcode 



dst 



10 



30 



IRR 



*12 if jump taken, 10 if not 
**This format is used in the example. 



Example: 



If the Carry flag is set to 1, the statement 

JP C,%1520 

replaces the contents of the Program Counter with %1520 and transfers control to that 
location. Had the Carry flag not been set, control would have fallen through to the 
statement following the 3P. 
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JR 

Jump Relative 



3R cc,dst 
Operation: 



Flags: 



If cc is true, PC ^- PC + dst 

If the condition specified by "cc" is true, the relative address is added to the Program 
Counter and control passes to the statement whose address is now in the Program Counter? 
otherwise, the instruction following the JR instruction is executed. (See section 5.5 for a 
list of condition codes.) The range of the relative address is ■♦•127, -128, and the original 
value of the Program Counter is taken to be the address of the first instruction byte 
following the 3R statement. 

No flags affected 



Instruction 
Fornat : 



cc 


Opcode 



dst 



Cycles 

10/12* 



Opcode 
(Hex) 



Addressing 
dst 



ccB RA 

cc = to F 



* 12 if jump taken, 10 if not 



Example: 



If the result of the last arithmetic operation executed is negative, then the four following 
statements (which occupy a total of seven bytes) are skipped with the statement 

3R MI, $+9 

If the result is not negative, execution continues with the statement following the JR. A 
short form of a jump to label LO is 

JR LO 

where LO must be within the allowed range. T+ie condition code is "blank" in this case, and 
JR has the effect of an unconditional JP instruction. 



Note: 



The $ refers to the address of the first byte of the instruction currently being executed. 
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LD 

Load 



LD dst,src 

Operation: dst -*-- src 

The contents of the source are loaded into 
unaffected. 


the destination. 


The contents 


of the source are 


Flags: No flags affected 


Instruction 
Format: 










Opcode 
Cycles (Hex) 

6 rC 
6 r8 

6 r9 

r=0 to F 

6 C7 
6 07 

10 E4 
10 E5 

10 E6 
10 06 

10 F5 

10 87 

10 97* , 
*This format is used 


Addressing Mode 
dst src 




dst 


Opcode 




src 




r IM 
r R 
















src 


Opcode 




dst 




R r 
















Opcode 




dst 


src 




r Ir 
Ir r 


















Opcode 




src 




dst 


R R 
R IR 


















Opcode 




dst 




src 


R IM 
IR IM 


















Opcode 




src 




dst 


IR R 


















Opcode 




dst 


src 




X * 


r x(r) 


















Opcode 




src 


dst 




X 


x(r) r 














in the example. 



Example : 



If working register contains %08, (11 decimal) and working ^register 10 contains ?o83, the 
statement 

LD 240(R0),R10 

loads the value %83 into register 251 (240 +11). The contents of working register 10 are 
unaffected by the load. 
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LDB 

Load Bit 



LDB clst,src,b 
LDB dst,b,src 

Operation: 



Example: 



dst(G) ^- src(b) 

or 
dst(b) --- src(O) 

The specified bit of the source is loaded into bit of the destination, or bit of the 
source is loaded into the specified bit of the destination. No other bits of the 
destination are affected. The source is unaffected. 



Flags: No flags affected 


Instruction 
Format: 














Cycles 

10 

10 


Opcode 
(Hex) 

47 
47 


Addressing Mode 
dst src 




Opcode 




dst 


b 







src 


ro Rb 




















Opcode 




src 


b 


1 




dst 


Rb ro 



















If working register 3 contains ?oOO and working register 5 contains 5aFF, the statement 

LDB R3,R5,//7 
leaves the value ?o01 in working register 3. 
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LDE/LDC 

Load Memory 



LDE/LDC dst,src 

Operation: dst -^ — src 



Flags: 



This instruction is used to load a byte from program or data memory into a working register 
or vice-versa. The contents of the source are unaffected. 

No flags affected 



Instruction 
Format : 



Opcode 



Opcode 



Opcode 



Opcode 



Opcode 



Opcode 



Opcode 



Opcode 



Opcode 



Opcode 



dst 


src 




src 


dst 




dst 


src 




src 


dst 1 




dst 


src* 




src 


dst* 




dst 


0000 




src 


0000 




dst 


0001 




src 


0001 



xs 




xs 




■<v 




x1l 




DA^ 




°\ 




°\ 




DA, 



Opcode Addressing Mode 
Cycles (Hex) dst src 



x1., 



OA^ 



DAl 



DA. 



DA , 



12 



12 



18 



18 



20 



20 



20 



20 



20 



20 



C3 



D3* 



E7 



F7 



A7 



B7 



A7 



87 



A7 



87 



Irr 



Irr 



r 


xs(rr) 


xs(rr) 


r 


r 


xl(rr) 


xKrr) 


r 


r 
DA 


DA 

Program 
Memory 

r 


r 


DAI 

[Data 
j Memory 



DA 



*The src or (rr) cannot use register pair 0-1. 
*This format is used in the example. 



Example: 



Note: 



If the working register pair 6-7 contains %404A and working register 2 contains ?b22, the 
statement 

LDE iRR6,R2 

will load the value %22 into data memory location ?o404A. 

LDE refers to data memory. 
LDC refers to program memory. 

The assembler makes Irr or rr even for program memory and odd for data memory. In the 
example above, the assembler produces this code: D3 27. 
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LDED/LDCD 

Load Memory and Decrement 



LDED/LDCO d3t,src 



Operation: 



Flags: 



dst -*-- arc 
rr -•— rr -1 

This instruction is used For user stacks or block transfers of data from program or data 
memory to the register file. The address of the memory location is specified by a working 
register pair. The contents of the source location are loaded into the destination 
location. The memory address is then decremented. The contents of the source are 
unaffected. 

No flags affected 



Instruction 
Format : 



Opcode 



dst 


src 



Cycles 

16 



Opcode 
(Hex) 

E2 



Addressing Node 
dst src 

r Irr 



Example: 

If working register pair 6-7 contains ?o30A3 and data memory locations %30A2 and %30A3 
contain ?o22BC, the statement 

LDED R2, iRR6 

loads the value SBC into working register 2 and the value 5o30A2 into working register pair 
6-7. A second statement 

LDED R2, iRR6 

loads the value %22 into working register 2 and the value Jo30A1 into working register pair 
6-7. 

Note: 

LDED refers to data memory. 
LDCD refers to program memory. 

The assembler makes Irr even for program memory and odd for data memory. In the example 
above, the assembler produces this code: E2 27. 

This instruction is the equivalent of a POPUD with the stack in memory rather than in the 
register file. 
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LDEI/LDCI 

Load Memory and Increment 



LDEI/LDCI dst,src 



Operation; 



Flags: 



dst -*-- src 
rr -*-- rr + 1 

This instruction is used for user stacks or block transfers of data from program or data 
memory to the register file. The address of the memory location is specified by a working 
register pair. The contents of the source location are loaded into the destination 
location. The memory address is then incremented ai^tomatically. The contents of the source 
are unaffected. 

No flags affected \ 



Instruction 
Format : 



Opcode 



dst 


src 



Cycleis 

16 



Opcode 
(Hex) 



Addressing Mode 
dst src 

r Irr 



Example: 

If working register pair 6-7 contains %30A2 and program memory locations ?o3QA2 and ?o30A3 
contain ?o22BC, the statement 

LDCI R2,iRR6 

loads the value %22 into working register 2, and working register pair 6-7 is incremented 
to 5o30A3. A second 

LDCI R2,iRR6 

loads the value %BC into register 2, and working register pair 6-7 is incremented to ?o30A4. 

Note: 

LOEI refers to data memory. 
LOCI refers to program memory. 

The assembler makes Irr even for program memory and odd for data memory. In the example 
above^ the assembler produces this code: E3 26. 

This instruction is the equivalent of a POPUI with the stack in memory rather than the 
register file. 
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LDEPD/LDCPD 

Load Memory with Pre-Decrement 



LDEPO/LDCPD dst,src 
Operation: 



Flags; 



rr -♦— rr - 1 
dst -♦— src 

This instruction is used for block transfers of data to program or data memory from the 
register file. The address of the memory location is specified by a working register pair 
and is first decremented. The contents of the source location are loaded into the 
destination location. The contents of the source are unaffected. 

No flags affected 



Instruction 
Format : 



Opcode 



src 


dst 



Cycles 

16 



Opcode Addressing Mode 
(Hex) dst src 



F2 



Irr 



Example: 



Note: 



If working register pair 6-7 contains 5o404B and working register 2 contains %22 (34 
decimal), the statement 

LDEPD iRR6,R2 

loads the value 9o22 into data memory location ?o404A and the value ?o404A into working 
register pair 6-7. 

LDEPD refers to data memory. 
LDCPD refers to program memory. 

The assembler makes Irr even for program memory and odd for data memory. 

This instruction is the equivalent of a PUSHUD with the stack in memory rather than the 
register file. 
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LDEPI/LDCPI 

Load Memory with Pre-lncrement 



OpetafciiSNn^ rr -♦- rr + 1 

dst -•— src 



Flags: 



This instruction is used For block transfers of data to proqrarti or data memory from the 
register file. The address of the memory location is specified by a working register pair 
and is first incremented. The contents of the source location are loaded into the 
destination location. The contents of the source are unaffected. 

No flags affected 



Instruction 
ForMst: 



Opcode 



src 


dst 



Cycles 

16 



Opccxle 
(Hex) 

r3 



Addressing Mode 
dst src 

Irr r 



Examples 



Note: 



If working register pair 6-7 contains %404A and working register 2 contains ?o22 (34 
decimal), the statement 

LDEPI @RR6,R2 

loads the value ?b22 into external data memory location %404B and the value ?o404B' into 
working register pair 6-7, 

LDEPI refers to data memory. 
LDCPI refers to program memory. 

The assembler makes Irr even for program memory and odd for data memory. 

This instruction is the equivalent of a PUSHUI with the stack in memory rather than the 
register file. ^ 
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LDW 

Load Word 


















LDW dst,src 

Operation: dst -«— src 

The contents of the source 
source are unaffected. 


(a word) are loaded into the destination. 


The contents of the 


Flags: No flags affected 


Instruction 
Fornat: 












Opcode 
Cycles (Hex) 


Addressing Mode 
dst src 




Opcode 




src 




dst 


10 C4 
in rs 


RR RR 
RR IR 






















Opcode 




dst 




src 


12 C6* 


RR IML 








! 




*This format is used in the example. 



Example: 



If the source operand is the immediate value ?o5AA5, the statement 

LDW RR6,#%5AA5 
leaves the value %5I\ in working register 6 and the value %A5 in working register 7. 



MULT 

Multiply (Unsigned) 



MULT dst, src 
Operation: 



Flags: 



dst -•— dst X src 

The 8-bit destination operand (even register of the register pair) is multiplied by the 
source operand (8 bits) and the product (16 bits) is stored in the register pair specified 
by the destination address. Both operands are treated as unsigned integers. 

C: Set if result is > 255; cleared otherwise. 

Z: Set if the result is 0; cleared otherwise. 

V: Cleared 

S: Set if MSB of the result is a 1; cleared otherwise. 

H: Unaffected 

D: Unaffected 



Instruction 
Format : 



Opcode 





Cycles 

24 
24 


Opcode 
(Hex) 

84* 
85 


Addressing Mode 
dst src 


dst 


RR R 
RR IR 



24 86 RR IM 
*This format is used in the example. 



Example : 



If working register 6 contains 5o40 (64 decimal) and working register 4. contains %42 (66 
decimal), the statement 

MULT RR6, R4 

leaves the value ?o10 in working register 6 and ?o80 in working register 7 (%1080 is 4224 
decimal). 
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NEXT 

Next 



NEXT 
Operation: 



Flags: 



PC -*- aiP 

IP ^- IP + 2 

This instruction is useful For the implementation of threaded-code languages. The program 
memory word pointed to by, the Instruction Pointer is loaded into the Program Counter. The 
Instruction Pointer is then incremented by two. 

No flags affected 



Instruction 
Format : 



Opcode 



Cycles 

14 



Opcode 
(Hex) 

OF 



Example: 



Before 



Note: 



After 







Address 




Data 






Data 


^^--^120 


Addr H 
Addr L 
Addr H 

NEXT 


01 \ 
301'V. 


43 
44 


Addr H 
Addr L 
Addr H 

Routine 




IP 


0043 


IP 0045 --^ 








^"^■-^ PC 01 30 \ 




PC 


0120 








V 






Memory 






Memory 





The examples for ENTER, EXIT, and NEXT illustrate how they could actually be used together 
in a program. 
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NOP 

No Operation 



NOP 
Operation: 



No action is performed by this instruction. It is typically used for timing delays. 



Flags: 



No flags affected 



Instruction 
Foraiat : 



Opcode 
Cycles (Hex) 



Opcode 



OR 

Logical OR 



OR dst,src 
Operation: 



Exanple : 



dst -*.- dst OR src , 

Tl>e source operand is logically ORed with the destination operand and the result is stored 
in the destination. The contents of the source are unaffected. The OR operation results in 
a 1 bit being stored whenever either of the corresponding bits in the two operands is 1; 
otherwise a bit is stored. 



Flags: C: 
Z: 
V: 
S: 
H: 
D: 


Unaffected 

Set if the result is 0; cleared otherwise. 

Always cleared to 

Set if the result bit 7 is set; cleared otherwise 

Unaffected 

Unaffected ' 


• 








Instruction 
Format : 














Opcode 
Cycles (Hex) 

6 42 
6 43 

10 44 
10 45 

10 46* 
*This format is used 


Addrea 
dst 

V 

r 

R 
R 

R 
in the 


src 




Opcode 




dst 


src 




r 

Ir 




















Opcode 




src 




dst 


R 
IR 




















Opcode 




dst 




src 


IM 
















example. 



If the source operand is the immediate value %7B (01111011) and the register named TARGET 
contains %C3 (11000011), the statement 

OR TARGET, //!fi7B 

leaves the value %FB (11111011) in register TARGET. 
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POP 

Pop 



POP dst 
Operation: 



Flags: 



dst <*-- iSP 

SP ^- SP + 1 

The contents of the location addressed by the Stack Pointer are loaded into the 
destination. The Stack Pointer is then incremented by one. 

No flags affected 



Instruction 
Format : 



Opcode 



Cycles 

10 
10 



Opcode Addressing Mode 
(Hex) dst 



50 
51* 



R 
IR 



*This format is used in the example. 



Example : 



If the Stack Pointer (control registers 216-217) contains %1000, external data memory 
location ?i1000 contains %55, and working register 6 contains ?o22 (34 decimal), the statement 

POP iR6 

loads the value ?o55 into register 34. After the POP operation, the Stack Pointer contains 
%1001. 



POPUD 

Pop User Stack (Decrementing) 



POPUD dstjsrc 

Operation: dst -*■- src 

IR ^_ IR _ 1 



Flags: 



This instruction is used for user-defined stacks in the register file. The contents of the 
register file location addressed by the user Stack Pointer are loaded into the destination. 
The user Stack Pointer is then decremented. 

No flags affected 



Instruct ion 
Format : 



Opcode 



dst 



Cycles 

10 



Opcxide Addressing Mode 
(Hex) dst src 



92 



IR 



Example : 



If the user Stack Pointer (register ?o42, for example) contains ?o80 and register ?o80 contains 
5A, the statement 

POPUD R2,!i%42 

loads the value 5b5A into working register 2. After the POP operation, the user Stack 
Pointer contains %7F. 
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POPUI 

Pop User Stack (Incrementing) 



POPUI dst,src 
Operation: 



riags: 



dst -*■- src 
IR ^- IR + 1 

This instruction is used for user-defined stacks in the register file. The contents of the 
register file location addressed by the user Stack Pointer are loaded into the destination. 
The user Stack Pointer is then incremented. 

No flags affected 



Instruction 
Fornat: 












Cycles 

10 


Opcode 
(Hex) 




Opcode 




src 




dst 


93 



Addressing Node 
dst src 

R IR 



Example : 



If the user Stack Pointer (register ?o42, for example) contains ?o80 and register %80 contains 
5o5A, the statement 

POPUI R2,i%42 

loads the value 5Ib5A into working register 2. After the POP operation, the user Stack 
Pointer contains %S^ . 



PUSH 

Push 



PUSH src 
Operation: 



Flags: 



SP ^- SP - 1 
gSP -*-- src 

The contents of the Stack Pointer are decremented, then the contents of the source are 
loaded into the location addressed by the decremented Stack Pointer, thus adding a new 
element to the top of the stack. 

No flags affected 



Instruction 
Format : 



Opcode 



Cycles 

10 Internal stack 
12 External stack 
12 Internal stack 
14 External stack 



Opcode 
(Hex) 

70* 

71 



Addressing Mode 
src 



IR 



*This format is used in the example. 



Example: 



If the Stack Pointer contains 551001, the statement 

PUSH FLAGS 

stores the contents of the register named FLAGS in location 5o1000. 
operation, the Stack Pointer contains %1000, 



After the PUSH 
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PUSHUD 

Push User Stack (Decrementing) 



PUSHUD dstjsrc 
Operation: 



Example: 



IR ^- IR - 1 

dst -*•- src 

This instruction is used for user-defined stacks in the register file. The user Stack 
Pointer is decremented, then the contents of the source are loaded into the register file 
location addressed by the decremented user Stack Pointer. 



Flags: No flags affected 


Instruction 
Format : 














Cycles 

10 


Opcode 
(Hex) 

82 


Addressing Mode 
dst src 




Opcode 




dst 




src 


IR R 



















If the user Stack Pointer (?o42, for example) contains ?o81 , the statement 

PUSHUD i5S42,R2 

stores the contents of working register 2 in location ?o80. After the PUSH operation, the 
user Stack Pointer contains ?o80. 



PUSHUI 

Push User Stack (Incrementing) 



Push User Stack (Incremehting) 



PUSHUI dst, src 
Operation: 



Flags: 



IR ^- IR + 1 

dst -f— src 

This instruction is used for user-defined stacks in the register file. The user Stack 
Pointer is incremented, then the contents of the source are loaded into the register file 
location addressed by the incremented user Stack Pointer. 

No flags affected 



Instruction 
Format : 












Cycles 

10 


Opcode 
(Hex) 




Opcode 




dst 




src 


83 



Addressing Mode 
dst src 

IR Ri 



Example : 



If the user Stack Pointer (?o42, for example) contains ?o81 , the statement 

PUSHUI i?542,R2 

stores the contents of working register 2 in location %82. After the PUSH operation, the 
user Stack Pointer contains ?o82. 
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RCF 

Reset Carry Flag 



RCF 

Operation: C ^«— 

The Carry flag is cleared to 0, regardless of its previous value. 
Flags: C: Cleared 'to 

No other flags affected 



Instruction 
Format : 



Opcode 



Cycles 

6 



Opcode 
(Hex) 

CF 



RET 

Return 



RET 
Operation: 



Flags: 



PC -^- iSP 
SP ^- SP + 2 

This instruction is normally used to return to the previously executing procedure at the end 
of a procedure entered by a CALL instruction. The contents of the location addressed by the 
Stack Pointer are popped into the Program Counters The next statement executed is that 
addressed by the new contents of the Program Counter .\ 

No flags affected 



Instruction 
Forinat : 



Opcode 



Cycles 



Opcode 
(Hex) 

AF 



Example: 



If the Program Counter contains ?o35B4, the Stack Pointer contains ?o2Q00, external 
data memory location ?o2000 contains Sb18, and location ?o2001 contains ?oB5, then the statement 

RET 

leaves the value ?o2002 in the Stack Pointer and ?»18B5, the address of the next instruction, 
in the Program Counter, 
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RL 

Rotate Left 



RL dst 
Operation: 



C ^- dst (7) 

dst (0) -•— dst (7) 

dst (n + 1) ^- dst (n) n = " 6 

The contents of the destination operand are rotated left one bit position. The initial 
value of bit 7 is moved to the bit position and also replaces the Carry flag. 



EW 



Flags: 



C: Set if the bit rotated from the most significant bit position was 1, i.e., bit 7 was 1. 

Z: Set if the result is 0; cleared otherwise. 

V: Set if arithmetic overflow occurred; cleated otherwise. 

S: Set if the result bit 7 is set; cleared otherwise. 

H: Unaffected 

D: Unaffected 



Instruction 
Format: 



Opcode Addressing Node 
Cycles (Hex) dst 



Opcpde 



dst 



90* 
91 



R 
IR 



*This format is used in the example. 



Example: 



If the contents of the register named SHIFTER are ?o88 (10001000), the statement 

RL SHIFTER 

leaves the value %^^ (00010001) in that register and the Carry and Overflow flags are set to 
1. 
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RLC 

Rotate Left Through Carry 



RLC dst 
Operation: 



dst (0) -*-- C 
C <•-- dst (7) 
dst (n + 1) -^- dst (n) n 



0-6 



The contents of the destination operand with the Carry flag are rotated left one bit 
position. The initial value of bit 7 replaces the Carry flag; the initial value of the 
Carry flag replaces bit 0. 



7 


Lc*_ ♦J 



Flags: 



C: Set if the bit rotated from the most significant bit position was 1, i.e., bit 7 was 1. 

Z: Set if the result is 0; cleared otherwise. 

V: Set if arithmetic overflow occurred, that is, if the sign of the destination changed 

during rotation; cleared otherwise. 

S: Set if the result bit 7 is set; cleared otherwise. 

H: Unaffected 

D: Unaffected 



Instruction 
Format : 



Opcode 



Cycles 

6 
6 



Opcode 
(Hex) 

10* 
11 



Addressing Mode 
dst 

R 
IR 



*This format is used in the example. 



Example: 



If the Carry flag is cleared to and the register named SHIFTER contains %&f (10001111), 
the statement 

RLC SHIFTER 

sets the Carry and Overflow flags to 1 and leaves the value SSIE (00011110) in SHIFTER. 
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RR 

Rotate Right 



RR d^st 
Operation: 



C ^- dst (0) • 

dst (7) ^- dst (0) 

dst (n) -^- dst (n + 1) n r - 6 

The contents of the destination operand are rotated right one bit position. The initial 
value of bit is moved to bit 7 and also replaces the Carry flag. 



EhM 



Flags: 



Cz Set if the bit rotated from the least significant bit position was 1, i.e., bit was 1. 

Z: Set if the result is 0; cleared otherwise. 

V: Set if arithmetic overflow occurred, that is, if the sign of the destination changed 

during rotation; cleared otherwise. 

S: Set if the result bit 7 is set; cleared otherwise. 

H: Unaffected 

0: Unaffected 



Instruction 
Format : 



Opcode 



Cycles 

6 
6 



Opcode 
(Hex) 

EO* 
El 



Addressing Mode 
dst 

R 
IR 



*This format is used in the example. 



Example: 



If the contents of register 6 are %31 (00110001), the statement 

RR R6 - ~ 

sets the Carry flag to 1 and leave the value ?o98 (10011000) in working register 6. Since 
bit 7 now equals 1, the Sign and Overflow flags are also set to 1. 
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RRC 

Rotate Right Through Carry 



RRC dst 
Operation: 



dst (7) -^- C 
C ♦- dst (0) 
dst (n) ^- dst (n + 1) n = - 6 

The contents of the destination operand and the Carry flag are rotated right one bit 
position. The initial value of bit replaces the Carry flag; the initial value of the 
Carry flag replaces bit 7, 



^-EH 



Flags: 



C: Set if the bit rotated from the least significant bit position was 1, i.e., bit was 1. 

Z: Set if the result is 0; cleared otherwise. 

V: Set if arithmetic overflow occurred, that is, if the sign of the destination changed 

during rotation; cleared otherwise. 

S: Set if the result bit 7 is set; cleared otherwise, 

H: Unaffected ^ 

0: Unaffected 



Instruction 
Format : 



Opcode 



dst 



Cycles 

6 
6 



Opcode 
(Hex) 

CO* 
CI 



Addressing Mode 
dst 

R 
IR 



*This format is used in the example. 



Example : 



If the contents of the register named SHIFTER are %0D (11011101), and the Carry flag is 
cleared to 0, the statement 

RRC SHIFTER 

sets the Carry and Overflow flags to 1 and leaves the value %6E. (01101110) in the register. 
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SBO 

Set Bank 



SBO 

Operation: BANK ^-0 

This instruction causes the Bank Address flag (bit 0) of Flag register 213 to be cleared to 



Flags: 



No flags affected 



Instruction 
Format : 



Opcode 



Opcode 
Cycles (Hex) 

6 4F 



SB1 

Set Bank 1 



SB1 
Operation: 

Flags: 



BANK ^- 1 

This instruction causes the Bank Address flag (bit 0) of Flag register 213 to be set to 1. 

No flags affected 



Inst rtjct ion 
Format : 



Opcode 



Opcode 
Cycles (Hex) 

6 5F 
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SBC 

Subtract With Carry 



SBC dst,src 
Operation; 



Flags: 



dst -«— dst 



src - C 



The source operand, along with the setting of the Carry flag, is subtracted from the 
destination operand and the result is stored in the destination, the contents of the source 
are unaffected. Subtraction is performed by adding the twos complement of the source 
operand to the destination operand. In multiple precision arithmetic, this instruction 
permits the carry ("borrow") from the subtraction of low-order operands to be subtracted 
from the subtraction of high-order operands. 

C: Set if a borrow occurred (src > dst); cleared otherwise. 

1: Set if the result is 0; cleared otherwise. ^ 

V: Set if arithmetic overflow occured, that is, if the operands were of opposite sign and 

the sign of the result is the same as the sign of the source; cleared otherwise. 
S: Set if the result is negative; cleared otherwise. 
H: Cleared if there is a carry from the most significant bit of the low-order four bits of 

the result; set otherwise, indicating a "borrow." 
D: Always set to 1. 



Instruction 
Format : 



Opcode 



dst 


src 



Opcode 



dst 



Opcode 



dst 



Cycles 


Opcode 
(Hex) 


Addressing Mode 
dst src 


6 
6 


32 
33* 


r 
r 


r 
Ir 


10 
10 


34 
35 


R 
R 


R 
IR 



10 



36 



IM 



*This format is used in the example. 



Example: 



If the register named MINUEND contains ?o16, the Carry flag is set to 1, working register 10 
contains ?o20 (32 decimal), and register 32 contains %05, the statement 

SBC MINUEND, ®R10 

leaves the value 5210 in register MINUEND. 
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SCF 

Set Carry Flag 



SCF 

Operation: C -«— 1 

The Carry flag is set to 1, regardless of its previous value. 
Flags: C: Set to 1 

No other flags affected 



Instruction 
Format : 



Opcode 



Opcode 
Cycles (Hex) 

6 DF 



SRA 

Shift Right Arithmetic 



SRA dst 
Operation: 



dst (7) ^- dst (7) 

C -*- dst (0) 

dst (n) ^- dst (n + 1) n = - 6 

An arithmetic shift right one bit position is performed on the destination operand. Bit 
replaces the Carry flag. Bit 7 (the sign bit) is unchanged, and its value is also shifted 
into bit position 6. 



7 6 



HD 



d 



Flags: 



C: Set if ttie bit shifted from the least significant bit position was 1, i.e., bit was 1. 

Z: Set if the result is 0; cleared otherwise. 

V: Always cleared to 

S: Set if the result is negative; cleared otherwise. 

H: Unaffected 

D: Unaffected 



Instruction 
Format : 



Opcode 



Cycles 

6 
6 



Opcode Addressing Mode 
(Hex) dst 



DO* 
D1 



R 
IR 



*This format is used in the example. 



Example: 



If the register named SHIFTER contains %B8 (10111000), the statement 

SRA SHIFTER 

clears the Carry flag to and leaves the value ?oDC (11011100) in the register SHIFTER. The 
Sign flag is set to 1 . 
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SRP/SRP0/SRP1 

Set Register Pointer 



SRP/SRP0/SRP1 src 
Operation: 



Flags: 



If src (1) = 1 and src (0) = then: RPO (3-7) -^- src (3-7) 

If src (1) = and src (0) = 1 then: RP1 (3-7) ,-•.- src (3-7) 

If src (1) = and src (0) = then: RPO (4-7) -•.- src (4-7), 

RPO (3) ^- 

RP1 (4-7) ^- src (4-7), 

RP1 (3) ^- 1 

The source data bits 1 and determine if one or both of the Register Pointers is to be 
written. Bits 3-7 of the selected Register Pointer are written unless both Register 
Pointers are selected. Then bit 3 of RPO is forced to a and bit 3 of RP1 is forced to a 
1. 

No flags affected 



Instruction 
Format : 



Opcode 



Cycles 

6 



Opcode Addressing Mode 
(Hex) src 



31 



IM 



Examples: 



(1 ) The statement 

SRPO #?i50 

sets Register Pointer (control register 214) to %50. 
The assembler produces this code: 31 52. 

(2) The statement 

SRP1 #%68 

sets Register Pointer 1 (control register 215) to 5S68. 
The assembler produces this code: 31 69, 

(3) The statement 

SRP #?i40 

sets Register Pointer to %40 and Register Pointer 1 to ?o48. 
The assembler produces this code: 31 40. 
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SUB 

Subtract 



SUB dst,src 
Operation: 



Flags: 



dst -«— dst - src 

The source operand is subtracted from the destination operand and the result is stored in 
the destination. The contents of the source are unaffected. Subtraction is performed by 
adding the twos complement of the source operand to the destination operand. 

C: Set if a "borrow" occurred; cleared otherwise. 

Z: Set if the result is 0; cleared otherwise. 

V: Set if arithmetic overflow occured, that is, if the operands were of opposite signs and 

the sign of the result is the same as the sign of the source operand; cleared otherwise. 
S: Set if the result is negative; cleared otherwise. 
H: Cleared if there is a carry from the most significant bit of the low-order four bits of 

the result; set otherwise indicating a "borrow." 
0: Always set to 1 , 



Instruction 
Format : 













Cycles 

6 
6 

10 
10 

10 


Opcode 
(Hex) 

22 
23 

24 
25 

26* 


Addressing Mode 
dst src 


Opcode 




dst 


src 




r r 
r Ir 














Opcode 




src 




dst 


R R 
R IR 














Opcode 




dst 




src 


R IM 



*This format is used in the example. 



Example; 



If the register named MINUEND contains ?o29, the statement 

SUB MINUEND," mi 
leaves the value %18 in the register. 
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SWAP 

Swap Nibbles 

^HAP dst 
Operation: 



dst (0 - 3) -•--^ dst (4-7) 

The contents of the lower four bits and upper four bits of the destination operand are 
swapped. 



7 4 3 



Flags: 



C: Undefined 

Z: Set if the result is 0; cleared otherwise, 

V: Undefined 

S: Set if the result bit 7 is set; cleared otherwise. 

H: Unaffected 

D: Unaffected 



Instruction 
Format : 



Cycles 



Opcode 
(Hex) 



Addressing Mode 
dst 



Opcode 



dst 



8 FO* R 

8 F1 IR 

*This format is used in the example. 



Example: 



If the register named BCD_Operands contains ?oB3 (10110011), then the statement 

SWAP BDCJDperands 
leaves the value %3B (00111011) in the register. 
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TCM 

Test Complement Under Mask 



TCM dst,src 
Operation: 



Example: 



(NOT dst) AND src 

This instruction tests selected pits in the destination operand for a logical "1" value. 
The bits to be tested are specified by setting a 1 bit in -the corresponding position of the 
source operand (mask). The TCM statement complements the destination operand, which is then 
ANDed with the source mask. The Zero (Z) flag can then be checked to determine the result. 
The destination and source operands are unaffected. 



Flags: C: 


Unaffected 










Z: 


Set if the result is 0; cleared otherwise. 










V: 


Always cleared to 0. 










Sz 


Set if the result bit 7 is set; cleared otherwise 










H: 


Unaffected 










D: 


Unaffected 










Instruction 














Fornat : 








Opcode 


Addressing Mode 








Cycles 


(Hex) 


dst 


src 














6 


62* 


r 








Opcode 




dst 


src 




r 
















6 

10 


63 

64 


r 

R 


Ir 
























Opcode 




src 




dst 




R 


















10 65 
10 66 
*This format is used 


R 
R 
in the 


IR 






















Opcode 




dst 




src 




IM 


















example. 



If the register named TESTER contains 5SF6 (11110110) and the register named MASK contains 
?b06 (00000110), that is, bits 1 and 2 are being tested for a 1 value, then the statement 

TCM TESTER, MASK 

complements TESTER (to 00001001) and then does a logical AND with register MASK, resulting 
in SbOO. a subsequent test of the Z flag 

3P Z, label 

causes a transfer of program control. At the end of this sequence, TESTER still contains 
%F6. 
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TM 

Test Under Mask 



TM dst,src 
Operation: 



Example: 



dst AND src 

This instruction tests selected bits in the destination operand for a logical "0" value. 
The bits to be tested are specified by setting a 1 bit in the corresponding position of the 
source operand (mask), which is ANDed with the destination operand. The Zero (Z) flag can 
then be checked to determine the result. The destination and source operands are 
unaffected. 



Flags: C: 
Z: 
Vz 
S: 
H: 
D: 


Unaffected 

Set if the result is 0; cleared otherwise. 

Always reset to 0. 

Set if the result bit 7 is set; cleared otherwise. 

Unaffected 

Unaffected 








Instruction 
Format : 










Cycles 


Opcode 
(Hex) 

72* 
73 

74 
75 

76 
mat is used 


Addres 
dst 

r 
r 

R 
R 

R 
in the 


src 




Opcode 




dst 


src 


6 


r 
Ir 
















' 






Opcode 




src 




dst 


10 
10 


R 
IR 






















Opcode 




dst 




src 


10 


IM 
















*This for 


example. 



If the register named TESTER contains 5oF6 (11110110) and the register named MASK contains 
?S06 (00000110), that is, bits 1 and 2 are being tested for a value, then the statement 

TM TESTER, MASK 

results in the value 5o06 (00000110), A subsequent test for nonzero 

3P NZ, label 

causes a transfer of program control. At the end of this sequence, TESTER still contains 
?iF6. 
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WFI 

Wait For Interrupt 



WFI 
Operation : 



Flags: 



The CPU is effectively halted until an interrupt occurs, except that DMA transfers still 
take place in the halt state. Either a fast interrupt or normal interrupt can take the CPU 
out of the halt state. 

No flags affected 



Instruction 
Format : 



Opcode 



Cycles 

6n 



Opcode 
(Hex) 



3F 
n = 1,2,3,... 



Example: 



Main Program 



EI (Enable Global Interrupt) 

. WFI (Wait for Interrupt) 

(next instruction) 



-interrupt occurs 
.►Interrupt Service Routine 



Clear Interrupt Flag 
IRET 



n 



Done with service routine 
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XOR 

Logical Exclusive OR 



XOR 



dst,src 



Operation: 



Example: 



dst -*— dst XOR src 

TKe source operand is logically EXCLUSIVE ORed with the destination operand and the result 
is stored in the destination. The EXCLUSIVE OR operation results in a 1 bit being stored 
whenever the corresponding bits in the operands are different; otherwise, a bit is stored. 



Flags: C: 
Z: 
V: 
S: 
H: 
D: 


Unaffected 

Set if the result is 0; cleared otherwise. 

Always reset to 0. 

Set if the result bit 7 is set; cleared otherwise 

Unaffected 

Unaffected 


• 




' 




Instruction 
Format: 














Opcode 
Cycles (Hex) 

6 B2 
6 B3 

10 84 
10 85 

10 86* 
*This format is used 


Addrea 
dst 

r 
r 

R 
R 

R 
in the 


tsing Mode 
src 




Opcode 




dst 


src 




r 
Ir 




















Opcode 




src 




dst 


R 
IR 




















Opcode 




dst 




src 


IM 
















example. 



If the source is the immediate value %1S (OIIIIDII) and the register named TARGET contains 
%C3 (11000011), the statement 

XOR TARGET, niB 

leaves the value ?bB8 (10111000) in the register. 
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Chapter 6 
Interrupts 



6.1 INTRODUCTION 



The interrupt structure of the SuperB consists of 
27 different interrupt sources, 16 vectors, and 8 
levels (Figure 6-1 ) . Two of the vectors are 
reserved for future members of the SuperB family. 

Interrupt priority is assigned by level, which is 
controlled by the Interrupt Priority register 
(IPR). Each level is masked (or enabled) accord- 
ing to the bits in the Interrupt Mask register 
(IMR), and the entire interrupt structure can be 
disabled by clearing bit in the System Mode 
register (R222). The three major components of 
the interrupt structure are sources, vectors, and 
levels. 



A source is anything that generates an interrupt. 
This can be internal or external to the Supers. 
Internal sources are hardwired to a particular vector 
and level, while external sources can be assigned to 
various external events. External interrupts are 
falling edge triggered. 

6.1.2 Vectors 

The vector number is used to generate the address 
of a particular interrupt servicing routine; 
therefore all interrupts using the same vector 
must use the same interrupt handling routine. 



INTERRUPT SOURCES 

COUNTER ZERO COUNT 
EXTERNAL INTERRUPT {P26) 
EXTERNAL INTERRUPT (P27) 

COUNTER 1 ZERO COUNT 
EXTERNAL INTERRUPT (PSe) 
EXTERNAL INTERRUPT (PS?) 

HANDSHAKE CHANNEL 1 
EXTERNAL INTERRUPT (P24) ' 
EXTERNAL INTERRUPT (P25) 

HANDSHAKE CHANNEL 1 I 
EXTERNAL INTERRUPT (P34) I 
EXTERNAL INTERRUPT (PSs) 



EXTERNAL INTERRUPT (P32) 
EXTERNAL INTERRUPT (P22) 

EXTERNAL INTERRUPT (P23) 
EXTERNAL INTERRUPT (P33) 

UART RECEIVE OVERRUN 
UART FRAMING ERROR 
UART PARITY ERROR 
UART WAKEUP DETECT 
-UART BREAK DETECT 
UART CONTROL CHAR DETECT 

UART RECEIVE DATA 
EXTERNAL INTERRUPT (PSq) 

EXTERNAL INTERRUPT (P2o) 

UART ZERO COUNT 
EXTERNAL INTERRUPT (P2i) 
UART TRANSMIT DATA 
EXTERNAL INTERRUPT (P3i) 



POLLING 


VECTORS 


LEVELS 








12 


IRQ2 




1 




1 




,4 








IRQ5 




1 








28 






' 


IRQ4 




^ 








30 








IR07 












■ 



















2 




IRQ3 






4 












6 








8 




IRQO 




. 


10 














16 
















,» 
















IRQ6 








20 
















22 
















24 


1 






1 


IRQ1 








26 








1 


j 
















1 



Figure 6-1 . Interrupt Structure 
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When more than one vector shares an interrupt 
level, the priorities of the vectors on that level 
are fixed. Figure 6-1 lists the vectors within a 
level in the order of decreasing priority (i.e., 
the top vector in each level has the highest 
priority). For example, for IRQ6, vector 16 
always has priority over vectors 18, 20, and 22. 



Although it does not cover all possible combina- 
tions, the Interrupt Priority register does 
provide the capability of assigning 192 different 
combinations of priority among the interrupt 
levels. For example, an IPR with the contents 
01101011 would have the following priority order 
(Figure 6-3): 



6.1.3 Levels 

While the sources and vectors are hardwired within, 
each level, the priorities of the levels can be 
changed by using the Interrupt Priority register 
(R255, Bank 0) (Figure 6-2). 



If more than one interrupt source is active, the 
source from the highest priority level is serviced 
first. If both sources are from the same level, 
the source with the lowest vector number has 
priority. For example, if the UART Receive Data 
bit and UART Parity Error bit are both active, the 
UART Parity Error is serviced first because it is 
vector 16 and the UART Receive Date^ bit is vector 
20. 



R25S BANK (FF) IPR 
INTERRUPT PRIORITY REGISTER 



E 



D4 D3 



Da Di I Do I 



GROUP PRIORITY - 



D7 D4 Di 



= UNDEFINED 
=B>C>A 
= A>B>C 
=B>A>C 
=C>A>B 

=:C>B>A 

= A>C>B 
= UNDEFINED 



L 



GROUP A 

= IRQ0>IRQ1 

1 = IRQ1>IRQ0 



= IRQ2 > (IRQ3,IRQ4) 

1 = (IRQ3,IRQ4) > IRQ2 

- SUBGROUP B 

= IRQ3 > IRQ4 

1 = IRQ4 > IRQ3 



- GROUP 

= IRQ5 > (IR06,IRQ7) 

1 = (IRQ6.IRQ7) > IRQ5 

- SUBGROUP C 

= IRQ6 > IRQ7 

1 =IRQ7>IRQ6 



Figure 6-2. interrupt Priority Register 





GROUP A 


GROUPS 


B22 




GROUP C 


A1 




A2 


B1 




B2 


01 




02 


B21 




C21 





EXAMPLE: An IPR with the contents 01 101011 would have 
the following priority order: 



022 
IRQ7 



HIGHEST 



EJ 


D4 


Di 


De 


Ds 


D3 


Da 


3 












L 


000 UNDEFINED 

001 B>C>A 




010 A>B>C 
Oil B>A>C 






100 C>A>B 

101 C>B>A 

110 A>C>B 

111 UNDEFINED 













A1>A2 

" 1 A2>A1 

B1>B2 

1 B2>B1 

B21>B22 

1 B22>B21 . 

C1>C2 

1 C2>C1 

C21>C22 

1 C22>C21 



LOWEST 



IRQ2 
IRQ4 
IRQ3 

IRQ7 
IRQ6 
IRQ5 

IRQ1 
IRQO 



GROUP B 



GROUP C 



GROUPA 



Figure 6-3. Interrupt Priority Tree 
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When an interrupt occurs, the software is auto- 
matically vectored to one of 16 possible service 
routines. If more than one active source shares 
that vector, the software must poll the individual 
sources connected with that vector to find the 
interrupting source or sources. Each interrupt 
source has its own Interrupt Enable bit located in 
the mode and control registers of the I/O section 



associated with the sdurce. The software has 
complete control over which sources are allowed to 
cause interrupts. If only one source associated 
with a particular vector is enabled, then when an 
interrupt occurs that uses that vector, no polling 
is required and the software is automatically 
vectored to the appropriate service routitie. 



Table 6-1. Supers Vector Address Tdble 



Vectors 
(Decinal Nenory Address) 



Levels 



Interrupt Sources 



30,31 

28,29 

26,27 

24,25 

22,23 
20,21 

18,19 

16,17 

14,15 

12,13 

10,11 

8,9 

6,7 

4,5 

2,3 

0,1 



IRQ7 P34 External Interrupt or HS1 / 
P35 External Interrupt 

IRQ4 P24 External Interrupt or HSO / 
P25 External Interrupt 

IRQ1 UART Transmit Data / 
P3-| External Interrupt 

IRQ1 UART Zero Count / 

P2^ External Interrupt 

IRQ6 P2o External Interrupt 

IRQ6 UART Receive Data / 

P3o External Interrupt 

IRQ6 UART Break / Control Character / 
Wake-Up 

IRQ6 UART Overrun / Framing / 
Parity 

IRQ5 Counter 1 Zero Count / 

P36 External Interrupt / 
P37 External Interrupt 

IRQ2 Counter Zero Count / 

P2g External Interrupt / 
P27 External Interrupt 

IRQO P33 External Interrupt 

IRQO P23 External Interrupt 

IRQ3 P22 External Interrupt 

IRQ3 P32 External Interrupt 

IRQ3 Reserved 

IRQ3 Reserved 
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6.1.4 Enables 

Interrupts can be enabled or disabled as follows: 

• Interrupt enable/disable. The entire interrupt 
structure can be enabled or disabled by setting 
bit in the System Mode register (R222). 

• Level enable. Each level can be enabled or 
disabled by setting the appropriate bit in the 
Interrupt Mask register (R221). 



The Supers then enters an interrupt machine cycle 
that completes the following sequence: 

• Resets the Interrupt Enable bit to disable all 
subsequent interrupts 

• Saves the Program Counter and status flags on 
the stack 

• Branches to the address contained within the 
vector location fojr the interrupt 



Level priority. The priority of each level can 
be controlled by the values in the Interrupt 
Priority register (R255, Bank 0). 

Source enable/diasble. Each interrupt source 
can be enabled or disabled in the source's Mode 
and Control register. 



6.1.5 The Interrupt Routine 

Interrupts are sampled at the end of each instruc- 
tion. Before an interrupt request can be granted 
a) interrupts must be enabled, b) the level must 
be enabled and must be the highest priority inter- 
rupting level, and c) the interrupt request must 
be enabled at the interrupting source and must 
have the highest priority within the level. 

If all this occurs, an interrupt request is 
granted. 



• Passes control to the interrupt servicing 
routine 

Interrupts can be re-enabled by the interrupt 
handling routine (EI instruction) , which allows 
interrupt nesting. First, however, the contents 
of the Interrupt Mask register should be saved and 
a new mask loaded which disables the present level 
being serviced and all lower levels. 

When the interrupt handling routine is finished, 
it should issue an Interrupt Return (IRET) 
instruction. This instruction restores the 
Program Counter and status flags from the stack 
and sets the Global Interrupt Enable bit. If 
nesting was used, the interrupt handling routine 
should first execute a Disable Interrupt (01) 
instruction and restore the saved mask before 
executing the IRET instruction. Figure 6-4 
illustrates the interrupt cycle process that 
occurs when an interrupt request occurs. 



HW RESET OR . 
POWER-UP RESET 



;=o* 



EXTERNAL 
INTERRUPTS " 



INTERRUPT PENDING REGISTER 
PORT 2/3 



POLLING 
' CYCLE 



INTERRUPT REQUEST REGISTER IRQ = o/oDC 



INTERRUPT PRIORITY 
REGISTER 



'^ — ;=o- 



INTERRUPT MASK 
REGISTER 



VECTOR 

INTERRUPT 

CYCLE 



Figure 6-4. Interrupt Cycle Process 
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6.2 FAST INTERRUPT PROCESSING 

The Supers provides a feature' called fast inter- 
rupt processing, which completes the interrupt 
servicing in 6 clock periods instead of the usual 
22. 

Any one of the eight interrupt levels can be 
programmed to use this feature by loading ttie fast 
interrupt select field of the System Mode register 
(R222) with the level number and setting the Fast 
Interrupt Enable bit. 

Two hardware registers support fast interrupts. 
The Instruction Pointer (IP) holds the starting 
address of the service routine and saves the 
Program Counter (PC) value when a fast interrupt 
occurs. A dedicated register, Flag', saves the 
contents of the Flag register when a fast inter- 
rupt occurs. 

To use this feature, software must first set the 
Instruction Pointer to the starting location of 
the interrupt service routine during initializa- 
tion and before interrupts are enabled for the 
first time. Then the level number is loaded into 
the Fast Interrupt Select field and the Fast 
Interrupt Enable bit in the System Mode register 
is turned on. 

When an interrupt occurs in the level selected for 
fast interrupt processing, the following occurs: 

• The contents of the Instruction Pointer and the 
Program Counter are swapped. 

• The contents of the Flag register are copied 
into Flag' . 

• The Fast Interrupt Status bit in the Flag 
register is set. 

• The interrupt is serviced. 

• When IRET is issued after the interrupt service 
routine is completed, the Instruction Pointer 
and the Program Counter are swapped again. 

• The contents of Flag' are copied back into the 
Flag register. 

• The Fast Interrupt Status bit " in the Flag 
register is cleared. 

After the Interrupt Return (IRET) of a fast 
interrupt, the Instruction Pointer (IP) will point 
to the next byte following the JRET. Before using 
the fast interrupt again, the IP should be re- 
initialized to point to the beginning pf the 



interrupt routine. While fast interrupt process- 
ing is enabled, normal interrupt processing still 
functions for the unselected levels. 

The Supers supports both polled and interrupt- 
driven systems or a combination of both. To 
accommodate a polled structure or a partially 
polled structure, any or all of the interrupt 
levels can be masked and the individual bits of 
the IRQ register polled. 



6.3 CLEARING THE INTERRUPT SOURCE 

Internally, the interrupt requests are represented 
as levels. This level-activated system requires 
that the software that services an interrupt must 
perform some action that removes the interrupting 
source before re-enabling that interrupt. 

For external interrupt inputs on the Port 2 and 3 
pins, edge- triggered "interrupt pending" flip- 
flops are used to convert an edge-triggered input 
to a level-activated interrupt. Thus, the service 
routine must reset the interrupt pending flip-flop 
to clear the interrupt request by writing to the 
Port 2/3 Interrupt Pending register. 

For receive character available interrupts from 
the UART receiver, emptying the Receive Data 
register (DIOR) will automatically clear 
the interrupt source. For receiver interrupts due 
to a receive error, detection of a control charac- 
ter, or detection of the wake-up condition, reset- 
ting the appropriate status bit in the Receive 
Control register (URC) will clear the interrupt 
source. For interrupts from the UART transmitter, 
filling the Transmit Data register (UIOT) will 
automatically clear the interrupt source. 

For end-of-count interrupts from the counter/ 
timers, resetting the Reset/End of Count Status 
bit (D-i) in the Counter Control register will 
clear the interrupt source. 

For interrupts from the on-chip DMA channel, load- 
ing a non-zero value into the DMA Count register 
will clear the interrupt source. 



6.4 INTERRUPT CONTROL REGISTERS 

The interrupt hardware is controlled by fields in 
the System Mode register (R222), the Interrupt 
Request register IRQ (R220), the Interrupt Mask 
register IMR (R221), the Interrupt Priority 
register IPR (R255, Bank 0), and the Fast Inter- 
rupt Status bit (FIS) of the Flags register 
(R213). 
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6. 4.1 Systea Node Register 

The System Mode register (R222) controls the mode 
of operation of the interrupt hardware. The 
format of the System Mode register is shown in 
Figure 6-5. 

The fields in this register pertaining to the 
interrupt hardware are: 

Global Interrupt Enable (Dg)* When this bit is 
set to 1, interrupts are enabled. When this bit 
is cleared to 0, all interrupts are disabled 
regardless of the state of individual interrupt 
enable or mask bits. This bit is automatically 
cleared during an interrupt machine cycle and can 
also be cleared by the DI instruction. It can be 
set by using an El or IRET instruction. A hard- 
ware reset clears this bit. 



Fast Interrupt Enable (Oi). When this bit is a 1, 
the fast interrupt processing feature is enabled 
for the selected interrupt level. When this bit is 
a 0, fast interrupt processing is disabled. When 
fast interrupt processing is used, the Interrupt 
Mask Register bit for the selected level must also 
be set. 

Fast Interrupt Select (02*0^). The value of this 
3-bit field selects the interrupt level for fast 
interrupt processing. All other levels still 
operate in the normal interrupt mode. 

(Bit 7 relates to external memory and not to 
interrupts. For more details on bit 7, see 
section 12.3.) 



R222 (DE) SYM 
SYSTEM MODE 



= 3-STATE MEMORY 
INTERFACE 

NOT USED 



1 D7 1 De 


Ds 


D4 


"oT 


D2 


Di 1 Do 1 








- 








L 















= GLOBAL INTERRUPT ENABLE 



-1 = FAST INTERRUPT ENABLE 
FAST INTERRUPT SELECT 



000 


LEVEL 


001 


LEVEL 1 


010 


LEVEL 2 


oil 


LEVELS 


100 


LEVEL 4 


101 


LEVELS 


110 


LEVELS 


111 


LEVEL? 



Figure 6-5. System Mode Register 



6.4.2 Interrupt Request Register 

The Interrupt Request (IRQ) register (R220) 
indicates which interrupt levels have pending 
interrupts. It takes a snapshot once for each 
instruction near the end of execution. Each bit in 
the register corresponds to one interrupt level. 
Software can use the IRQ for polling those levels 
that are not using hardware interrupts and have 
been masked off by the IMR. Even when polling, 
the software is responsible for removing the 
interrupting source when servicing that source. 



Writing to the IRQ has no effect. The interrupt 
request must be renewed at the source, such as the 
DART or a port. 

External interrupts are disabled by a reset and 
must be enabled via execution of an El instruction 
before bits in the Port 2/3 Interrupt Pending 
registers can be set and external hardware inter- 
rupts can occur. 

The format of the Interrupt Request register is 
shown in Figure 6-6. 



R220(DC)IRO 
INTERRUPT REQUEST (READ ONLY) 




Figure 6-6. Interrupt Request Register 
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6.4.3 Interrupt Mask Register 

The Interrupt Mask (IMR) register (R221) is used 
to mask individual interrupt levels, thus prevent- 
ing interrupts at that level, A 1 enables inter- 
rupts at that level, a disables them. 
Interrupts should be globally disabled before 
writing to this register. 

The format of the Interrupt Mask register is shown 
in Figure 6-7. 



R221 (DD) IMR 
INTERRUPT MASK 




Figure 6-7. Interrupt Mask Register 



6.4.4 Interrupt Priority Register 

The Interrupt Priority (IPR) register (R255, Bank 
0) defines the priority order of the interrupt 
levels. The coding of this register is defined in 
Figure 6-2. Interrupts should be globally dis- 
abled before writing to this register. 



6.4.3 Fast Interrupt Status Bit (FIS of Flags 
Register) 

This is a status bit; when it is set to 1 , it 
indicates that a fast interrupt has occurred. 
This bit determines what type of action is taken 
during an IRET. If it is a 1, then an IRET causes 
a swap between the Program Counter and the 
Instruction Pointer, and the Flags' register to be 
written into the Flag register. If it is a 0, 
then IRET causes a normal interrupt return. A 
hardware reset clears this bit to 0. 

The format of the Flags register is shown in 
Figure 5-1, Chapter 5. 



6.5 INTERRUPTS AND THE DMA CHANNEL 

When the DMA channel is enabled to work with a 
handshake- driven I/O port or the UART, the inter- 
rupt request from the specific device is replaced 
by an interrupt request from the DMA channel when 
the specified number of transfers has been com- 
pleted (see Figure 6-8). 



DMA 






i— — V 


DMA 




T -1 1 








REQUEST 


INTERRUPT 






:0-i 




FROM DEVICE 


^ V-J 


zh 


"^S___ TO IRQ 

^ REGISTER 


DMA 






END OF COUNT * 






■ ^ 





Figure 6-8. Interrupts and the DIVIA 
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7.1 RESET 

A system reset, activated by a low level on the 
ftESfeT input, overrides all other operating condi- 
tions and puts the SuperS into a known state. The 
RE Set input is internally synchronized with the 
internal clock of the Supers to form the internal 
reset line. For a power-up reset operation when 
using the on-chip oscillator, the RE^Et input must 
be held low for at least 50 milliseconds after the 
power supply is within tolerance to allow the on- 
chip clock oscillator to stabilize. If an exter- 
nal clock oscillator is used or power has been 
applied long enough for the on-chip oscillator to 
stabilize, then the RESET input must be held low 
for at least 18 clock periods to cause a system 
reset , 

While rEsET is active low, the t57 output is forced 
low while T^ pulses low once every four clock 
cycles and R/^ remains high. Z-BUS-compatible 
peripherals use the 7^ and 155" coincident low state 
as a peripheral reset function. 



Resets also result in the following: 

• Interrupts are disabled (the Global Interrupt 
Enable bit is cleared and the Interrupt Request 
register is disabled) 

• Ports 2, 3, and 4 are placed in input mode 

• In parts with on-chip ROM, Ports and 1 are 
placed in input mode; in ROMless parts. Port 1 
is configured as an address/data bus to exter- 
nal memory while Port bits 0-4 are configured 
as address bits 8-12 and bits 5-7 are in input 
mode 

• The on-chip peripherals are all disabled 

• The Program Counter is loaded with 0020^ 

Table 7-1 shows the reset values of the control 
and peripheral registers. Specific reset values 
are shown by Is or Os, while an x indicates bits 
whose states are not defined and t indi^cates not 
used. 
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Table 7<-1. Control and Peripheral Register Reset Values 

Register Naae 
NnemmiCy Decimal » Hex D7 Dg 65 D4 D3 D2 0^ Dq Cdnnents 

General Registers 

Program Control Flags xxxxxxOO Bank 0, no fast interrupts 

FLAGS, R213, D5 



Register Pointer 
RPO, R214, D6 

Register Pointer 1 
RP1, R215, D7 

Stack Pointer 
SP, R216-7, D8-D9 

Instruction Pointer 
IP, R218-9, DA,DB 

Interrupt Request 
IRQ, R220, DC 

Interrupt Mask 
IMR, R221, DD 

System Mode 
SYM, R222, DE 



110 Working register CO 

110 10 Working register C8 



xxxxxxxx 



xxxxxxxx 



000000 Interrupts disabled 



xxxxxxxx 



OttxxxOO Disable interrupts 

disable 3-state 



External Memory Timing 01111100 3 wait states for Program 



EMT, R254, FE 
(Bank 0) 



and Data, Slow memory 



Interrupt Priority 
IPR, R255, FF 
(Bank 0) 



xxxxxxxx 



Port Registers 

Port 

PO, R208, DO 

Port 1 

PI, R209, D1 



xxxxxxxx 



xxxxxxxx 



Key 1 = Reset value of 1 
= Reset value of 



X = bits whose states are not defined 
t = not used 
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Table 7>1. Control and Peripheral Register Reset Values (Continued) 



Register 



D^ D^ D5 D^ D3 D2 0<| Dq Cooments 



Port Registers (Continued) 



Port 2 

P2, R210, D2 



11111111 



Output register = 1 
Value will not be 
observable until ports 
are configured as output 



Port 3 

P3, R211, D3 



11111111 



Output register = 1 
Value will not be 
observable until ports 
are configured as output 



Port 4 

P4, R212, D4 



xxxxxxxx 



Handshake Control 
HOC, R244, F4 



xxxxxOxO 



Disable handshake 

Ports 1 and 4, disable DMA, 

(write only) 



Handshake 1 Control 
H1C, R245, F5 



xxxxxxxO 



Disable handshake 
Port (write only) 



Port 4 Direction 
P4D, R246, F6 



11111111 



Inputs 



Port 4 Open-Drain 
P40D, R247, F7. 



00000000 Push-pull 



Port 2/3 Mode 

P2AM, R248-251, F8,F9,FA,FB 

(Bank 0) 



00000000 



Inputs (write only) 
(P2AM, P2BM, P2CM, P2DM) 



Port 2/3 Interrupt 

Pending 
P2AIP, R252-3, FC,FD 



00000000 



(Write only) software 
reset (P2AIP, P2BIP) 



Port Mode 





POM, R240, FO 





(Bank 0) 




Port Mode 


t 


PM, R241, F1 . 




(Bank 0) 


t 



With ROM: input/output 

11111 ROMless: 1 = Address 



t 1 1 With ROM: Port 0/1 inputs 

(write only) 
t 1 1 ROMless: Port 0/1 outputs 



Key: 1 = Reset value of 1 
= Reset value of 



X = bits whose states are not defined 
t = not used 
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Table 7-1. Control and Peripheral Register Reset Values (Continued) 
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Register 



070503041)31)21X11)0 DMHMntS 



UART and DMA Registers 



UART Transmit Control 10 
UTC, R235, EB 



Disable transmitter, 
transmit buffer empty 



UART Receive Control 
URC, R236, EC 



00000000 



Disable receiver 

No character received 



UART Interrupt Enable 00000000 
UIE, R237, ED 



Disable interrupts 



UART Data 
UIO, R239, EF 



xxxxxxxx 



UART Baud-Rate Generator xxxxxxxx 
UBG, R248-9, F8,F9 
(Bank 1) 



UART Mode A 
UMA, R250, FA 
(Bank 1) 



xxxxxxxx 



UART Mode B 
UMB, R251, FB 
(Bank 1) 



00000000 Disable baud-rate generator 



Wake-Up Match 
WUMCH, R254, FE 
(Bank 1) 



xxxxxxxx 



Wake-Up Mask 
WUMSK, R255, FF 
(Bank 1) 



xxxxxxxx 



DMA Count 

DC, R240-1, F0,F1 

(Bank 1) 



xxxxxxxx 



Counter Registers 



Counter Control 
COCT, R224, EO 
(Bank 0) 



xxOOOOOO 



Disable counter 0, 
interrupts, software 
capture 



Key: 1 = Reset value of 1 
= Reset value of 



X = bits whose states are not defined 
t = not used 



Reset and Clock 



Table 7-1. Cdntrol and Peripheral Register Reset Values (Continued) 

Register D7 D5 D5 D4 D3 D2 D^ Dg Coanents 

Counter Registers (Continued) 

Counter 1 Control xxOOOOOO Disable counter 1, 
C1CT, R225, E1 interrupts, software 

(Bank 0) capture 

Counter Capture xxxxxxxx 
COC, R226-7, E2,E3 
(Bank 0) 

C 

Counter 1 Capture xxxxxxxx 

C1C, R228-9, E4,E5 
(Bank 0) 

Counter Mode OOOOxxxx Port 2 I/O 

COM, R224, EO 
(Bank 1) 

Counter 1 Mode OOOOxxxx Port 3 I/O 

C1M, R225, E1 
(Bank 1) 

Counter Time Constant xxxxxxxx 
COTC, R226-7, E2,E3 
(Bank 1) 

Counter 1 Time Constant xxxxxxxx 
C1TC, R228-9, E4,E5 
(Bank 1) 



Key: 1 = Reset value of 1 x = bits whose states are not defined 

= Reset value of t = not used 
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Eight clock cycles after RE'Stt has returned high, 
the Supers starts program execution. The initial 
instruction fetch is from location 0020|^. The 
first program segment executed is typically a 



routine' to initialize the control registers to the 
required system configuration. Figures 7-1 and 7-2 
show the reset timing. 
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Figure 7-1 . Reset Timing for ROIVIIess Devices 
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7.2 aocK 

The Supers derives its timing from on-board clock 
circuitry connected to pins XTAL1 and XTAL2. The 
clock circuitry consists of an oscillator, a 
divide-by-two shaping circuit, and a clock 
buffer. Figure 7-3 illustrates the clock 
circuitry. 

The oscillator's inputs are XTAL1 and XTAL2, which 
can be driven by a crystal, a ceramic resonator, 
or an external clock source. The divide-by-two 
circuit can also be driven directly from a TTL 
level on the XTAL1 pin. 



XTAL1 
XTAL2 



->- 



INTERNAL 
CLOCK 



Figure 7-3. Supers Clock Circuit 



Crystals and ceramic resonators would be connected 
across XTAL1 and XTAL2 and should have the follow- 
ing characteristics to ensure proper oscillator 
operation: 



Cut: 

Node: 

Output Frequency: 

Resistance: 

Capacitance: 



AT (crystal only) 
Parallel, fundamental 
1 MHz-12 MHz 
100 ohms maximum 
30 pf maximum 



When an external frequency source is used, only 
the XTAL1 input needs to be driven. Any TTL- 
compatible driver can be used for this function. 
The XTAL2 input can be left floating. 
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Chapter 8 
I/O Ports 



8.1 INTRODUCTION 

The Supers has 40 line^ dedicated to input and 
output. These are grouped into five ports of 
eight lines each. All the lines can be configured 
as inputs or outputs; some can be configured as 
address/data lines. All por^s have TTL-compatible 
input and output characteristics and can drive two 
standard TTL loads. 



8.3 PORT 

Port (R208) can be configured as I/O or as an 
address output port for addressing external memory 
on a bit basis. Those bits selected as I/O can be 
configured as all inputs or all outputs. When 
configured as outputs, the option exists to select 
open-drain outputs. The open-drain option does 
not apply to those bits configured as address 
lines. 



8.2 GENERAL STRUCTURE 

In general, each bit of the five ports has an 
associated input register, output register, and 
buffer and control logic. When the CPU writes to 
a port, it causes data to be stored in the output 
register. Those bits of that port configured as 
outputs enable the output buffer, and the output 
register contents are present on the external 
pin. If those bits configured as outputs are read 
by the CPU, the data present on the external pin 
is returned. Under normal output loading, this is 
the equivalent of reading the output register. 
However, if a bit of the port is configured as an 
open-drain output, the data returned may not be 
the value contained in the output register; rather 
it is the value forced on the input pins by the 
external system. 

When a bit of any port is defined as an input, 
reading that bit causes data present on the exter- 
nal pin to be returned. Ports that are under 
handshake control are an exception. Reading a 
handshake-driven input bit returns the data last 
latched into the input register by the input- 
strobe . 

Bits configured as inputs can be written to by the 
CPU, but in this case, the data is stored in the 
output register and cannot be read back because 
the output buffer is disabled. However, if the 
input bits are reconfigured as output bits, the 
data stored in the output register is then 
reflected on the output pins. This mechanism 
allows the user to initialize outputs prior to 
driving their loads. 



Accesses to Port are made by reading and writing 
to register R208 (DOj^ in set one). When a Port 
bit is configured as an address output, it 
cannot be accessed as a register (writes have no 
effect, reads return the state of the external 
pin). When used as an I/O port. Port may be 
placed under handshake control by using the facil- 
ities of Handshake Channel 1 (see section 8.8). 

The following control registers are associated 
with configuring Port 0: 

• Port Mode register (R241, Bank 0). Controls 
direction of I/O lines and selection of open- 
drain or push-pull outputs. 



Port Node register (R240, Bank 0). 

ures each bit as I/O or address bit. 



Config- 



Handshake 1 Control register (R2459 Bank 0). 

Controls enabling and configuration of hand- 
shake signals. 



8.4 PORI 1 

Port 1 (R209) can be configured as an address/data 
port for interfacing external memory or as a byte 
I/O port. The configuration is set using the Port 
Mode register (R241, Bank 0). (For a description 
of Port 1 as part of the external memory inter- 
face, see section 12.3.) When configured as a 
byte output port, there is an option to select 
open-drain outputs on the entire port. In the 
ROMless parts. Port 1 is always an address/data 
bus and cannot be programmably configured. 
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When configured as an input or output port, 
accesses are made to Port 1 via reads or writes to 
register R209 (D1^ in set one). When Port 1 is 
configured as a multiplexed address/data port, it 
cannot be accessed as a register; writes have no 



effect and reads return an FFu 



When used as an 



I/O port. Port 1 can be placed under handshake 
control by using the facilities of Handshake 
Channel (see section 8.8). 

The following control registers are associated 
with configuring Port 1: 

• Port Node register (R241, Bank 0). Controls 
Port 1 configuration (input port, output port, 
or address/data bus) and selection of open- 
drain or push-pull outputs, 

• Handshake Control register (R244» Bank 0). 

Controls the enabling and configuration of the 
handshake signals. 



8.5 PORTS 2 AT© 3 

Ports 2 and 3 (R210 and,R211) are used to provide 
the external control inputs and outputs for the 
DART, the handshake channels, and the counter/ 
timers. The relationship between port pins' and 
their control function is shown in Table 8-1 . 
When Port 2 and 3 bits are not used for control 
inputs and outputs, they are available for use as 
general-purpose I/O lines and/or external inter- 
rupt inputs. Each bit is individually configured 
as to its function. 

When Ports 2 and 3 are used as general-purpose I/O 
lines, the direction of each bit can be configured 
individually. Each bit selected as an output can 
also be configured individually as an open-drain 
or push-pull output. All inputs of Ports 2 and 3 
are Schmidt-triggered. 



The following control registers are associated 
with configuring Ports 2 and 3: 

• Port 2/3 A Node register (R248, Bank 0). 

Controls the configuration of bits and 1 
(input, input with interrupt enabled, push-pull 
input, open-drain output). 



0). 



Port 2/3 B Node register (R249, Bank 

Controls configuration of bits 2 and 3. 



• Port 2/3 C Node register (R250, Bwik 0). 

Controls configuration of bits 4 and 5. 



Port 2/3 D Node register (R231, Bmk 

Controls configuration of bits 6 and 7. 



0). 



The various control functions are enabled in the 
control register for the associated device (Hand- 
shake Control register. Counter Mode register, 
etc.). When using Port 2 and 3 pins as control 
signals, the Port 2/3 Mode registers must still be 
programmed to specify which bits are inputs and 
which bits are outputs. 

Each bit of Ports 2 and 3 can be used as an exter- 
nal interrupt input. Each bit used as an external 
interrupt input must be configured as an input, 
but may still be used as an external control input, 
or as a general-purpose input line. Each external 
interrupt bit has an edge-triggered "interrupt- 
pending" flip-flop that captures the external 
interrupt requests. Software can read and reset 
the edge-triggered flip-flops without affecting 
the normal I/O operation of the bit. Each external 
interrupt has its own interrupt enable control 
that determines if that bit is allowed to cause an 
interrupt. The edge-triggered flip-flops still 
capture edges when the interrupt enable control is 
disabled. Port 2 is accessed as general register 
R210, Port 3 as general register R211. 



Table 8-1. Ports 2 and 3 Control Functions 



— 


Port 2 — 





Port 3 — 


Bit 


Function 


Bit 


Function 





UART Receive Clock 





UART Receive Data 


1 


UART Transmit Clock 


1 


UART Transmit Data 


2 


Reserved 


2 


Reserved 


3 


Reserved 


3 


Reserved 


4 


Handshake Input 


4 


Handshake 1 Input/TOt 


5 


Handshake Output 


5 


Handshake 1 Output /I5R 


6 


Counter Input 


6 


Counter 1 Input 


7 


Counter I/O 


7 


Counter 1 I/O 
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Two registers are directly associated with the 
interrupt flip-flops: 

• Port 2/3 A Interrupt Pending register (R252y 
Bank 0). Controls interrupt flip-flops for 
bits 0, 1, 2 and 3 of Ports 2 and 3. 

• Port 2/3 B Interrupt Pending register (R253, 
Bank 0). Controls interrupt flip-flops for 
bits 4, 5, 6, and 7 of Ports 2 and 3. 

These registers can be used to poll the external 
interrupts and to reset the interrupt pending bits 
(the flip-flops). Reading these registers returns 
the state of the interrupt pending flip-flop. 
When writing to these registers, writing a 1 to a 
bit position clears that flip-flop and writing a 
to a bit position has no effect. 



8.7 PORT NODE AND CONTROL REGISTERS 

The ports are configured and controlled by the 
following set of registers: 

• Port Mode 

• Port Mode 

• Port 2/3 A Mode 

• Port 2/3 B Mode 

• Port 2/3 C Mode 

• Port 2/3 D Mode 

• Port 2/3 A Interrupt Pending 

• Port 2/3 B Interrupt Pending 

• Port 4 Direction 

• Port 4 Open-Drain 



8.7.1 Port Mode Register 



The Interrupt Mask register (R221) and Port 2/3 
Mode registers determine which interrupts are 
enabled. 



The Port Mode register provides some additional 
mode control for Ports and 1 . The fields in 
this register are (Figure 8-1): 



8.6 PORT 4 

Port 4 (R212) is always an l/O port whose direc- 
tion can be configured on a bit-by-bit basis. 
Each bit configured as an output can be configured 
individually as an open-drain or push-pull output. 

Port 4 I/O lines are accessed via reads and writes 
to register R212 (D4j^ in set one). 

Port 4 can be placed under handshake control by 
using the facilities of Handshake Channel (see 
section 8.8). 

The following control registers are associated 
with configuring Po:|:t 4: 

• Port 4 Direction register (R246, Bank 0). 

Controls direction of each bit of Port 4. 

• Port 4 Open-Drain register (R247, Bank 0). 

Selects open-drain or push-pull for each Port 4 
output. 

• Handshake Control register (R2449 Bank 0). 

Controls the enabling and configuration of the 
handshake signals. 



R241BANK0(F1)PM 
PORT MODE (WRITE ONLY) 



I D7 I Pg I Ds 



J 



PORT 1 MODE 

00 I OUTPUT 

01 INPUT 

1X I ADDRESS/DATA 



D4 D3 D2 Di Do 



L 



PORTO DIRECTION 

= OUTPUT 

1 = INPUT 
OPEN-DRAIN PORT 

= PUSH-PULL 

1 = OPEN-DRAIN 
OPEN DRAIN PORT 1 

= PUSH-PULL 

1 = OPEN-DRAIN 
ENABLE DM P35 

= DISABLE 

1 = ENABLE 



Figure 8-1 . Port Mode Register 



Port Direction (Dg). If this bit is a 1, all 

bits of Port configured as I/O will be inputs. 
If this bit is a 0, then the I/O lines will be 
outputs. A hardware reset forces this bit to a 1. 

Open>Drain Port (D<|). jLf this bit is a 1, all 

bits of Port configured as outputs will be 
open-drain outputs; if 0, they will be push-pull 
outputs. This bit has no effect on those bits not 
configured as outputs. A hardware reset forces 
this bit to a 0. 

Qpen>Drain Port 1 (02). If Port 1 is configured 
as an output port and this bit is a 1, then all of 
the port will be open-drain outputs. If this bit 
is a 0, they will be push-pull outputs. This bit 
has no effect if Port 1 is not ^ configured as an 
output port or A/Dg-y. A hardware reset forces 
this bit to a 0. 



602 



I/O Ports 

Enable Wf (O3). If this bit is a 1, Port 35 is 
configured as Data Memory output line (!5R). A 
hardware reset forces this bit to a 0. 

Port 1 Hode (D4-D5). This field selects the 
configuration of Port 1 as an output port, input 
port, or address/data port as part of t;he external 
memory interface. The coding for this field is as 
follows: 



Field 

00 
01 
IX 



Function 

Output port 
Input port 
Address/data 



A hardware reset forces this field to the 01 
(input port) state. The ROMless part has this 
field forced to IX. 



8.7.2 Port Node Register 

The Port Mode register programs each bit of Port 
as an address output (part of an external memory 
interface) or as an I/O bit (Figure 8-2). When a 
bit of this register is a 1 , the corresponding bit 
of Port is defined as an address output. When a 
0, the corresponding bit of Port is defined as 
an I/O bit. For ROMless parts, ^ hardware reset 
forces this register to all Is for pins PO0-PO4 
and Os for pins PO5-PO7; for parts with on-chip 
ROM, a hardware reset forces all pins to 0. 

R240 BANK 0(F0) POM 
PORTO MODE 



P7 De 



D3 



Di Do 



PO7MODE 
POeMODE 
PO5 MODE 



J 



PO4MODE- 



L 



POqMODE 
PO1 MODE 
PO2 MODE 
PO3MODE 



= I/O; 1 = ADDRESS 



Figure 8-2. Port Mode Register 



8.7.3 Port 2/3 Node Registers 

The Port 2/3 A Mode, Port 2/3 B Mode, Port 2/3 C 
Mode, and Port 2/3 D Mode registers control the 
modes of Ports 2 and 3 (Figures 8-3, 8-4, 8-5, and 
8-6). A separate 2-bit field for each of the bits 



of Ports 2 and 3 configures the bit as input or 
output. The field also controls whether the bit 
is enabled ais an external interrupt source and 
selects the output as open-drain or push-pull. 
The field is coded as follows: 



Field Function 

00 Input 

01 Input and interrupt enabled 

10 Output, push-pull drivers 

11 Output, open-drain 

A hardware reset forces all bits of the four 
registers to the state, 

R248BANK0(F8)P2AM 
PORT 2/3 A MODE (WRITE ONLY) 



P3i MODE 
P3o MODE 



1 D7 1 De I Ds 


D4 |d3 


D2 1 Di 1 Do 1 















P2oMODE 
P2i MODE 



INPUT 

INPUT, INTERRUPT ENABLED 
OUTPUT, PUSH-PULL 
OUTPUT, OPEN-DRAIN 



Figure 8-3. Port 2/3 A Mode Register 



R249BANK0(F9)P2BM 
PORT 2/3 B MODE (WRITE ONLY) 


[d7 De D5 


D4 


0, 


D2 Di DoJ 








P33MODE 1 




I P22 MODE 








do 
01 
10 
11 


INPUT 
INPUT 
OUTP 
OUTP 


, INTERRU 
JT, PUSH- 
JT, OPEN- 


PULL 
DRAIN 



Figure 8-4. Port 2/3 B Mode Register 



R250BANK0(FA)P2CM 
PORT 2/3 C MODE (WRITE ONLY) 



P35MODE 
P34MODE 



1 D7 1 De 1 Ds 


D4|d3 


D2 1 Dr Do 1 












1 



P24 MODE 
P25MODE 



INPUT 

INPUT, INTERRUPT ENABLED 
OUTPUT, PUSH-PULL 
OUTPUT, OPEN-DRAIN 



Figure 8-5. Port 2/3 C Mode Register 
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R251BANK0(FB)P2DM 
PORT 2/3 D MODE (WRITE ONLY) 



E 


De 


Ds 


D4 


O3 


D2 1 Di Do 1 








P37MODE — 1 




1 P26MODE 


Figure 8 






' 


)0 INPUT 

)1 INPUT, INTERRUPT ENABLED 

OUTPUT, PUSH-PULL 

1 OUTPUT, OPEN-DRAIN 

-6. Port 2/3 D Mode Register 



8.7*4 Port 2/} Interrupt Pending Registers 

The Port 2/3 A Interrupt Pending and Port 2/3 B 
Interrupt Pending registers represent the software 
interface to the negative edge^riggered flip-flops associated 
with external interrupt inputs. Each bit of these registers 
corresponds to an interrupt generated by an external source. 
When one of thfese registers is read, the value of each bit 
represents the state of the corresponding interrupt. When 
one of these registers is written to,a 1 in a bit position causes 
the corresponding edge-triggered flip-flop to be reset to 0; a 
causes no action. 

The software interfaces with these registers to 
poll the interrupts and also to reset pending 
interrupts as they are processed. The relation- 
ship between these registers and the corresponding 
externally generated interrupts is shown in 
Figures 8-7 and 8-8. A hardware reset forces all 
interrupt edge- triggered flip-flops to the 
state. 



R252BANK0(FC)P2AIP 
PORT 2/3 A INTERRUPT PENDING 



D7 De ps O4 D3 D2 Di Do 



P33 
P32 
P23 
P22 



J 



L 



P2o 
P2i 
P3o 
P3i 



8. 7. 5 Port 4 Direction Register 

Thfe Port 4 Direction register defines the I/O 
direction of Port 4 on a bit basis (Figure 8-9). 
If a bit in this register is a 1, the correspond- 
ing bit of Port 4 is configured as an input line. 
If the bit is a 0, the corresponding bit of Port 4 
is configured as an output line. A hardware reset 
forces this register to the all 1s state. 

R246BANK0(F6)P4D 
PORT 4 DIRECTION 



O7 De Ds D4 D3 D2 Di Do 



-P40-P47 I/O DIRECTION 
= OUTPUT; 1 = INPUT 



Figure 8-9. Port 4 Direction Register 



8.7.6 Port 4 Open-Drain Register 

The Port 4 Open-Drain register defines the output 
driver type for Port 4 (Figure 8-10). If a bit of 
Port 4 has been configured as an output and the 
corresponding bit in the Port 4 Open-Drain 
register is a 1, then the Port 4 bit will have an 
open-drain output driver; if it is a 0, then the 
Port 4 bit will have a push-pull output driver. 
If the bit of Port 4 has been configured as an 
input, then the corresponding bit in the Port 4 
Open-Drain register has no effect. A hardware 
reset forces this register to the all Os state. 



R247BANK0(F7)P4OD 
PORT 4 OPEN-DRAIN 



E 


De 


Ds 


D4 


D3 


D2 


Di 


Do 















P40-P47 OPEN-DRAIN 

= PUSH-PULL; 1 = OPEN-DRAIN 



Figure 8-7. Port 2/3 A interrupt Pending Register 



Figure 8-10. Port 4 Open-Drain Register 



8.8 HAIDSHAKING CHANNELS 

The Super8 has two handshaking channels. Channel 
"0" is associated with Ports 1 or 4; Channel "1" 
is associated with Port 0. They are identical in 
function except Channel also has DMA capability. 



R253BANK0(FD)P2BIP 
PORT 2/3 B INTERRUPT PENDING 



I D7 De Ds D4 D3 D2 Di Do I 



J 



P27- 

PZe" 



L 



P24 
P25 
P34 
P35 



Figure 8-8. Port 2/3 B interrupt Pending Register 



There are two basic modes of operation. The first 
is the "fully interlocked" or two-wire mode. In 
this mode, there is an incoming control wire and 
an outgoing control wire. Each transition on a 
control wire must be answered by a transition on 
the other control wire before the first can make 
another transition. Thus both the sender and 
receiver control the data transmission rate. 
Figures 8-11 and 8-12 illustrate the operation of 
the "fully interlocked handshake." 
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DAV 
(INPUT TO SUPERB) 



RDY 
(OUTPUT FROM SUPERS) 



DATA ON PORT 
(INPUT TO SUPERS) 




State 1 . Ready output is high indicating that the Supers is ready to accept data 

State 2. The I/O device puts data on the port and then activates the DAV input This causes the 
data to be latched into the port input register and generates an interrupt or DMA request 

State 3. The Supers forces the Ready (RDY) output low, signaling to the I/O device that the data 
has been latched 

State 4. The I/O device returns the DAV line high in response to RDY going low. 

State 5. The Supers DMA or interrupt software must respond to the service request and read the con- 
tents of the port in order for the handshake sequence to be completed. The RDY line goes high 
if, and only if, the port has been read and DAV is high. This returns the interface to its initial state 



Figure 8-1 1 . Supers Input Handshake— Fully Interlocked Mode 



RDY 
(INPUT TO SUPERS) 



DAV 
(OUTPUT FROM SUPERS) 



DATA ON PORT 
(OUTPUT FROM SUPERS) 




State 1 . RDY input is high indicating that the I/O device is ready to accept data 

State 2. The Supers writes to the port register to initiate a data transfer Writing the port outputs 

new data and forces DAV low if, and only if, RDY is high and set-up time is done 
State 3. The I/O device forces RDY low after latching the data. RDY low causes an interrupt or DMA 

req uest t o be generated. The Supers can write new data in response to RDY going low. 
State 4. The DAV o utput from the Supers is driven high in response to RDY going low. 
State 5. After DAV goes high, the I/O device is free to raise RDY high thus returning the interface 

to its initial state 



Figure 8-12. Super8 Output Handshake— Fully Interlocked Mode 



The second mode is the "strobed" or single-wire 
mode. In this mode there is a single control wire 
and it is generated by the sender. Figures 8-13 
and 8-14 illustrate the operation of "strobed" 
handshaking . 



Each channel has a 4-bit counter, called the 
Deskew Counter, that is used to count processor 
clocks. In the "strobed" mode, this counter is 
used to generate the set-up time and strobe width 
for the output handshake. In the "fully inter- 



DAV 
(INPUT TO SUPERS) 



DATA ON PORT 
(INPUT TO SUPERS) 




Figure 8-13. Super8 Input Handshake— Strobed Mode 
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DAV 
(OUTPUT FROM SUPERS) ' 



\^ 



*-|— SET-UP 



DATA ON PORT 
(OUTPUT FROM SUPERS) 



Z)C 



THE SET-UP AND STROBE MINIMUM TIMES ARE DETERMINED 
BY THE VALUE IN THE DESKEW COUNTER. 



Figure 8-14. Supers Output Handshake— Strobed Mode 



locked" model the counter generates the set-up 
time. This set-up time is the delay between 
outputting valid data at the port and activating 
the Data Available handshake signal. The Deskew 
Counter can be loaded with a value from 1 to 16 
that represents the minimum number of CPU clock 
cycles in the data set-up and strobe times. 

The direction of data transfer during handshake is 
determined by the selected direction of bit of 
the parallel port associated with the handshake 
channel. This also controls the DMA direction 
when used. 



needed by the handshake function. Note that the 
open-drain options of Ports 2 and 3 can be applied 
to the handshake outputs. Note also that Port 2 
and 3 pins used by the handshake channels as 
inputs can still be used as external interrupt 
pins to drive the handshake service routines. 

Handshake Input. This input provides the DAV 
signal for input handshaking or the RDY signal for 
output handshaking. 

Handshake Output. This output provides the RDY 
signal for input handshaking or the T5RV signal for 
output handshaking. 



8*8.1 Pin Descripticms 

The handshake channels each use two pins of Ports 
2 and 3 (bits 4 and 5) for interfacing with the 
external world: 



Handshake Channel Input 
Handshake Channel Output 

Handshake Channel 1 Input 
Handshake Channel 1 Output 



P24 
P25 

P34. 



The individual Port 2 and 3 pins should be con- 
figured for the appropriate I/O direction as 



8.8.2 Handshake Control Registers 

Each handshake channel is controlled by an 8-bit 
control register (Figures 8-15 and 8-16). Hand- 
shake Control register (R244) and Handshake 1 
Control register (R245) include the controls for 
enabling handshakes , selecting the associated port 
(Channel only), selecting the handshake type, 
enabling DMA capability (Channel only), and 
initializing the Deskew Counter. The fields in 
these registers are: 



R244 BANK 0(F4) HOC 
HANDSHAKE CONTROL (WRITE ONLY) 



D7 



De 



D3 



.Di Do 



DESKEW COUNTER - 
(RANGE 1-16) 



L. 



HANDSHAKE ENABLE 



- PORT SELECT: 
1 =PORT1;0 = PORT4 

■ DMA ENABLE: 
1 = ENABLED 
= DISABLED 



1 = FULLY INTERLOCKED 
= STROBED 



Figure 8-15. Handshake Control Register 
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R245 BANK 0(F5) Hie 
HANDSHAKE 1 CONTROL (WRITE ONLY) 



DESKEW COUNTER ■ 
(RANGE 1-16) 



L= 



HANDSHAKE ENABLE 

- ISIOT USED 

-MODE: 
1 = FULLY INTERLOCKED 
= STROBED 



Figure 8-16. Handshake 1 Control Register 



Handshake Enable (Dg). When this bit is set to 1, 
the handshake function is enabled. 

Port Select (Channel only)(Di). This bit 
selects which port is controlled by Handshake 
Channel 0, When it is set to 1, Port 1 . is 
selected and when it is cleared to 0, Port 4 is 
selected. 

DNA Enable (Channel only)(D2). ^^^^ ^^^^ ^^^ ^^ 
set to 1, the DMA function is enabled for Hand- 
shake Channel 0. When it is cleared to 0, the DMA 
function is not used by the handshake channel and 
may be used by the UART. 



Mode (03), When this bit is set to 1, the "fully 
interlocked" mode is enabled. When it is cleared 
to 0, the "strobed" mode is enabled. 

Deskew Counter (D4-D7). This 4-bit field is used 
to select a count value from 1 to 16 (0000-1111). 
This value is the number of processor clocks used 
to generate the set-up and strobe when using the 
"strobed" mode, or the set-up when using the 
"fully-interlocked" mode. 
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Chapter 9 
Counter/Timers 



9.1 INTRODUCTION 

The Supers has two identical 16-bit counter/timers 
that can be programmed! independently. They can be 
cascaded to produce a counter 32 bits in length 
and can operate from internal inputs (as timers) 
or external inputs (counters). When used as 
timers, the internal input is the internal CPU 
clock divided by two, which is the XTAL divided by 
four. Figure 9-1 shows the counter/timer block 
diagram. 



The counter /timers can count up or down. The 
direction can be controlled on, the fly by either 
software or an external event. 

The counter/timers have the option of single cycle 
or continuous counting capability. In the single 
cycle mode, the counters count to zero (up or 
down) from the preset time-constant value and then 
stop. In the continuous mode, counting is 
continuous and each time the counter reaches zero, 
it is reloaded with the preset time-constant value 
from the Time Constant register (or the Capture 
register in bi-value mode). 






i-O 



«- 



R — 

E 
G 
I 
S 



<^ 



<: 




Figure 9-1 . Counter/Timer Block Diagram 
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9.1.1 Bi-Value Node 

Another option allows either a single or dual 
(bi-value) preset time constant value. In 
bi-value mode, both the Time Constant register and 
Capture register are used to supply load values to 
the counter/ timer. The two registers alternate 
in loading the counter/timer each time the 
counter/timer makes a transition between a count 
of and a count of FFFF^^ when counting down, or 
between a count of FFFFh and when counting up 
(assuming continuous mode operation), or when a 
trigger causes the counter/timer to be reloaded. 
This can be used to produce an output pulse train 
with a variable duty cycle. The bi-value feature 
is not available when the capture feature is 
enabled and vice versa. Upon enabling a 
counter/timer in bi-value mode from a previously 
disabled condition, the initial load of the 
counter/timer is from the Time Constant register. 



The external event can be either the rising edge 
of the counter/timer I/O line {Ply for C/TO, P^y 
for C/T1) or both edges. On the rising edge, the 
current count value is loaded into the Capture 
register. If capture on both edges is enabled, the 
current count value is loaded into the Time 
Constant register on the falling edge, overwriting 
the initial load value for that counter. 

The capture feature is not available when the 
bi-value counting feature is being used and vice 
versa. 

If interrupts are enabled, the interrupt request 
is generated on the transition from a count of 
to a count of FFFFj^ or from a count of FFFF^ 
to a count of 0, and/or on an external event. If 
configured for an external output, the output pin 
toggles at this same count change. 



9.1.2 Capture 



9.1.3 external Gate and Trigger 



Another feature, called "capture on external 
event," takes a snapshot of the counter when a 
specific event occurs. The external event can be 
simulated by software. When "captured," the 
current value in the counter is loaded into a 
special register that can subsequently be 
read via software. The capture feature is needed 
to look at counters on the fly, especially 
cascaded counters. 



The counter/timers have an external gate capabil- 
ity. When this feature is selected, an external 
input line (GATE) is monitored. The counting or 
timing operation is performed only when this line 
is low. The gate facility is illustrated in 
Figure 9-2. 



COUNTER OR 
TIMER INPUT 



A COUNT OCCURS HERE: 



n n 



JUl 



Figure 9-2. Gate Facility 



TRIGGER INPUT 



COUNTER OR 
TIMER INPUT 



A COUNT OCCURS HERE: 



n 



J — L 



J — I TL- 



Figure 9-3. Trigger Operation 



GATE/TRIGGER 
INPUT 



/■ 



COUNTER OR TIMER INPUT 



"v^^ — \__y 



_jn TL-jn TL 



A COUNT OCCURS HERE: 



n. 



Figure 9-4. Gate/Trigger Function 
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An external input can be used as a trigger input 
to a counter/timer. When this feature is selected, 
an external line is monitored. A software trigger 
is also present in a control register. The 
trigger input to the Counter /Timer is an OR of the 
software and hardware triggers. Prior to a low- 
to-high transition on the trigger, the Counter is 
disabled. After the low- to-high transition on the 
trigger, counting is enabled. Retriggerable or 
non-retriggerable mode can be selected. 

Clearing the Counter Enable bit in the Control 
register also resets the triggered cohditipn; a 
new trigger must be received after the Counter 
Enable bit is set again before counting will 
resume. The trigger operation is illustrated in 
Figure 9-3. 

One input line (GATE/TRIGGER) can be used for both 
the gating and the triggering functions. An 
initial low-to-high transition on this line acts 
as a trigger and subsequent low signals on this 
line function as gate signals (Figure 9-4). 



9.2 COUNT£R/TIMER CONTROL AND MODE REGISTERS 



The Mode and Control registers determine the 
counter /timer operations. The Mode register 
selects the configuration of the counter/timers 
and is generally loaded only at initialization 
time, while the Control register handles those 
features that are likely to be dynamically 
changed. 

The Time Constant register contains the initiali- 
zation value for the counter/timer and also holds 
the counter value saved on the falling edge of 
P27/P37 when capture on both edges is enabled. 

The Capture register holds the counter value saved 
when using the "capture on external event" func- 
tion. When capture on both edges is enabled, it 
holds the value saved on the rising edge of 
P2"7/P37. It also holds a second initialization 
value when using the bi-value counting feature. 



9.2.1 Counter/Tiner Control Registers 

The fields in these registers, as shown in Figures 
9-5 and 9-6, are: 



Each counter/timer has an 8-bit Mode register, an 
8-bit Control register, a 16-bit Time Constant 
register, and a 16-bit Capture register. 



= SINGLE CYCLE 
1 = CONTINUOUS 



= COUNT DOWN - 
1 = COUNT UP 



1 = LOAD COUNTER - 



J 



1 = SOFTWARE TRIGGER - 



R224, BANKO(EO)COCT 
COUNTER CONTROL 



D7 De D5 D4 D3 D2 Di Do 



L 



1 = ENABLE COUNTER 

READ 1 = END OF COUNT 
WRITE 1 = RESET END OF COUNT 

- 1 = ZERO COUNT INTERRUPT ENABLE 
- 1 = SOFTWARE CAPTURE 



Figure 9-5. Counter Control Register 



= SINGLE CYCLE 
1 = CONTINUOUS 



J 



= COUNT DOWN - 
1 = COUNT UP 

1 = LOAD COUNTER - 



1 = SOFTWARE TRIGGER - 



R225BANK0(E1)C1CT 
COUNTER 1 CONTROL 



I P7 I De 



D5 



L,„ 



ENABLE COUNTER 



READ 1 = END OF COUNT 
" WRITE 1 = RESET END OF COUNT 



- 1 = ZERO COUNT INTERRUPT ENABLE 

- 1 = SOFTWARE CAPTURE 



Figure 9-6. Counter 1 Control Register 
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Enable Counter (Dq). When this bit is set to 1, 
the counter/timer is enabled; operation begins on 
the rising edge of the first processor clock 
period following the setting of this bit from a 
previously cleared value. Writing a 1 in this 
field when the previous value was 1 has no effect 
on the operation of the counter/timer. When this 
bit is cleared to 0, the counter/timer performs no 
operation during the next (and subsequent) 
processor clock periods. A hardware reset forces 
this bit to 0. Both counters are clocked by the rising edge of 
the incoming signal on P26 or P36 after the counter is 
enabled. The maximunn frequency of the external clock 
signal applied to P36 (P26) equals the nnaximum Xtal fre- 
quency divided by 4. The maximum quaranteed Xtal fre- 
quency for the Supers is 20 MHz, which implies a maximum 
counter frequency of 5 MHz. 

Reset/End of Count Status (Di). This bit is set 
to 1 each time the counter reaches 0. Writing a 1 
to this bit resets it, while writing a has no 
effect. 

Zero Count Interrupt En^le (02). When this bit 
is set to 1 , the counter/timer generates an inter- 
rupt request when it counts to 0. A hardware reset 
forces this bit to 0. 

Softifare Capture (D3). When this bit is set to 1, 
the current counter value is loaded into the 
capture register. This bit is automatically 
cleared following the capture. 

Software Trigger (D^), This bit is effectively 
"ORed" with the external rising-edge trigger input 
and can be used by the software to force a trigger 
signal. This bit produces a trigger signal 
regardless of the setting of the Input Pin Assign- 
ment field of the Mode register. This bit is 
automatically cleared following the trigger. 



This operation alone does not start the Counter. 
This bit is automatically cleared following the 
load. 

Count Up/DoMn (Dg). This bit determines the count 
direction if internal up/down control is specified 
in the Mode register. A 1 indicates up, a down. 

Continuous/Single C^cle (D^). When this bit is set to 1 

the counter is reloaded with the time-constant value when the 
counter reaches the end of the terminal count. The terminal 
count for down counting is 0000, while the one for up counting 
Is FFFF. When this bit is cleared to 0, no reloading occurs. 



9.2.2 Counter/Tiaer Node Registers 

The fields in these registers, as shown in Figure 
9-7 and 9-8, are: 

Capture Node (D^, Dg). This 2-bit field selects 
the capture or bi-value count mode. A value of 01 
enables capture on the rising edge of the 1/0 pin, 
a value of 11 enables capture on both edges of the 
I/O pin, a value of 10 enat)les the bi-value count 
mode and disables capture, and a value of 00 
disables both capture and bi-value load. 

Programaed/Extemal Up/Doun Control (D2). A 1 

enables programmed up/down control and a enables 
external up/down control. If external up/ down is 
enabled, a on P27/P37 indicates down and a 1 
indicates up. 



Load Counter (D5). The contents of the Time 
Constant register are transferred to the Counter 
prescaler one clock period after this bit is set. 



Enable Retrigger (03). When this bit is set to 1, 
the time-constant value is automatically loaded 
into the Counter/Timer register when a trigger 



INPUT PIN ASSIGNMENTS: 



R224 BANK 1 (EO) COM 
COUNTER MODE 



D7 De D5 D4 D3 D2 Di Do 



D7 De D5 D4 P27 


P26 








I/O 


I/O 







I/O 


TRIGGER 


1 





GATE 


I/O 


1 




GATE 


TRIGGER 


1 





I/O 


CO INPUT 


1 




TRIGGER 


CO INPUT 


1 1 





GATE 


CO INPUT 


1 1 




GATE/ 








TRIGGER 


CO INPUT 


1 




CO OUTPUT 


I/O 


1 




CO OUTPUT 


TRIGGER 


1 1 




CO OUTPUT 


GATE 


1 1 




CO OUTPUT 


GATE/TRIGGER 


1 1 





CO OUTPUT 


CO INPUT 



L 



CAPTURE MODE: 

00 = NO CAPTURE 

01 = CAPTURE ON RISING 

EDGEOFP27 

10 =: BI-VALUE LOAD 

11 = CAPTURE ON BOTH 

EDGES OF P27 

= EXTERNAL 

UP/DOWN CONTROL P27 

1 = PROGRAMMED 

UP/DOWN CONTROL 

1 = pNABLE RETRIGGER 



1 1 1 1 — CASCADE COUNTERS 



Figure 9-7. Counter Mode Register 
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INPUT PIN ASSIGNMENTS: 
D7 De D5 D4 P37 P36 



R225BANK1(E1)C1M 
COUNTER 1 MODfe 



De D5 D4 D3 D2 Di Do 















I/O 


I/O 











1 


I/O 


TRIGGER 








1 





GATE 


I/O 








1 


1 


GATE 


TRIGGER 





1 








I/O 


01 INPUT 





1 





1 


TRIGGER 


01 INPUT 





1 


1 





GATE 


01 INPUT 





1 


1 


1 


GATE/ 
TRIGGER 


01 INPUT 


1 











01 OUTPUT 


I/O 


1 








1 


01 OUTPUT 


TRIGGER 


1 





1 





01 OUTPUT 


GATE 


1 





1 


1 


01 OUTPUT 


GATE/TRIGGER 


1 


1 








01 OUTPUT 


01 INPUT 



H 



CAPTURE MODE: 

00 = NO CAPTURE 

01 = CAPTURE ON RISING 

EDGE OF P37 

10 = BI-VALUE MODE 

11 = CAPTURE ON BOTH 

EDGES OF P37 

= EXTERNAL 

UP/DOWN CONTROL P37 

1 = PROGRAMMED 

UP/DOWN CONTROL 

1 = ENABLE RETRIGGER 



Figure 9-8. Counter 1 Mode Register 



input is received while the counter/timer is 
counting (Counter/Timer not equal to 0). When 
this bit is cleared to 0, no reloading occurs. 

Input Pin Assignnents (O^-Dy). This 4-bit field 
specifies the functionality of the port lines 
associated with the counter/timer. It also deter- 
mines whether the counter/timer will monitor an 
external input (counting operation) or use the 
scaled internal processor clock (timing opera- 
tion). The four bits in the field select the 
following options: enable output (EO), external 
signal or internal clock (C/T), enable gate facil- 
ity (G), and enable triggering facility (T). The 



selected options determine the functions asso- 
ciated with each external line of the counter/ 
timer as illustrated in Table 9-1. A hardware 
reset forces these four pins to 0. 

If 1111 is coded in this field in the Counter 
Mode register, then the two counter/timers are 
linked together as a 32-bit counter with Counter 
as the low-order 16 bits and Counter 1 as the 
high-order 16 bits. Counter 1 selects the mode 
and control options for the 32-bit counter and 
external accesses are made through the lines 
associated with Counter 1 (P3g and P3j) , 











Table 9-1. IPA Field encoding 


in Counter Mode 


Registers 


IPA Field 




— Pin Functionality - 


--. 




EO 


C/T 


G 


T 


Counter/Timer I/O 


Counter/Timer Input 




o? 


«>6 


»5 


D4 


(P27 or P37)* 


(P26 or P36)* 


Notes 














I/O 




I/O 


Timer 













I/O 




Trigger 


Timer 












Gate 




I/O 


Timer 












Gate 




Trigger 


Timer 





1 







I/O 




Input 


Counter 





1 






Trigger 




Input 


Counter 





1 







Gate 




Input 


Counter 





1 






Gate/ trigger 




Input 


Counter 













Output 




I/O 


Timer 











Output 




Trigger 


Timer 












Output 




Gate 


Timer 











Output 




Gate/trigger 


Timer 




1 








Output 




Input 


Counter 




1 







Undefined 




Undefined 


Reserved 




1 







Undefined 




Undefined 


Reserved 




1 






Undefined 




Undefined 


Reserved for Counter 1 , 
Cascade for Counter 



Counter/timer - P27 and P25 
Counter/timer 1 - P3-7 and P3g 
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The counter/timer I/O line (P27 for C/TO, P3j for 
C/T1) is also used as the external capture input 
if the capture feature is enabled, and the up/down 
control input (O=down, 1=up) if external up/down 
control is enabled. 



9.2.3 Tiae Constant Register 

This 16-bit register pair holds the value that is 
automatically loaded into the counter/timer 1 ) 
when the counter/timer is enabled, 2) in contin- 
uous mode, when the count reaches zero, or 3) in 
re- trigger mode, when the trigger is asserted. If 
capture on both edges is enabled, then this regis- 
ter captures the contents of the counter on the 
falling edge of the I/O pin. 

The format of the Time Constant register is 
illustrated in Figure 9-9. 



9.2.4 Capture Register 

This 16-bit register pair is used to hold the 
counter value saved when using the "capture on 
external event" function. This register will 
capture at the rising edge of the I/O pin or when 
software capture is asserted. When the bi-value 
mode of operation is enabled, this register is 
used as a second Time Constant register and the 
counter is alternately loaded from each. 

The format of the Capture Register is shown in 
Figure 9-10. 



R226BANK0(E2)C0CH 
COUNTER CAPTURE 



D7 



D5 



D3 



D2 



Do] 



- HIGH BYTE (COC8-COC15) 



R226 BANK 1 (E2) COTCH 
COUNTER TIME CONSTANT 



Dy De 



Di Do 



• HIGHBYTE(C0TC8-C0TCi5) 



R227 BANK 0(E3) COOL 
COUNTER CAPTURE 



I D7 De D5 D4 D3 D2 Di Do I 



• LOW BYTE (COC0-COC7) 



R227 BANK 1 (E3) COTCL 
COUNTER TIME CONSTANT 



De 



Oo 



■ LOW BYTE (COTC0-COTC7) 



R228BANK0(E4)C1CH 
COUNTER 1 CAPTURE 



D3 



■ HIGH BYTE (C1Cb-C1Ci5) 



R228BANK1(E4)C1TCH 
COUNTER 1 TIME CONSTANT 



E 



D4 



Da 



Do| 



■ HIGH BYTE (CITC8-CITC15) 



R229BANK0(E5)C1CL 
COUNTER 1 CAPTURE 



D7 De D5 D4 O3 D2 Di Do 



■ LOW BYTE (CIC0-CIC7) 



R229BANK1(E5)C1TCL 
COUNTER 1 TIME CONSTANT 



E 



De 



Do 



- LOWBYTE(C1TCo-ClTC7) 



Figure 9-10. Capture Register Fbrmat 



Figure 9-9. Time Constant Register Format 
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10.1 INTRODUCTION 

The universal asynchronous receiver/transmitter 
(UART) is a full-duplex asynchronous channel. 
Transmission and reception can be accomplished 
independently with 5 to 8 data bits per character, 
plus optional even or odd parity, and an optional 
wake-up bit. 

Data can be read into or out of the UART via 
R239. This single address is able to serve a 
full-duplex channel because it contains two com- 
plete 8-bit registers — one for the transmitter and 
the other for the receiver. 



10.2 TRANSMITTER 

When the UART's register address is specified as 
the destination (dst) of an operation, the data is 
output on the UART. The UART automatically adds 
the start bit, the programmed parity bit (odd, 
even, or no parity), and the programmed number of 
stop bits to the data character to be trans- 
mitted. The transmitter can also add a Wake-Up 
bit (optional) between the parity bit (or the last 
bit in the character if parity is disabled) and 
the first stop bit, as shown in Figure 10-1. When 
the character is five, six, or seven bits long, 
the unused bits in the Transmit Data register 
(UIO) are automatically ignored by the UART. 

Serial data is shifted from the transmitter at a 
rate equal to 1, 1/16th, 1/32nd, or 1/64th of the 
clock rate supplied to the transmitter clock input 
(as determined by the clock-rate field in the UMA 
register). Serial data is shifted out on the 
falling edge of the transmitter clock. 



The Transmit Data output (P3i) line is held mark- 
ing (high) when the transmitter has no data to 
send. If the Send Break (SENBRK) bit of the UART 
Transmit Control (UTC) register is set to 1, the 
Data Output line will be held spacing (low) until 
it is cleared. 



10.3 RECEIVER 

An asynchronous receive operation begins when the 
Receive Enable bit (RENB) in the UART Receive 
Control register (URC) is set. A low (spacing) 
condition on the Receive Data line (PJq) indicates 
a start bit. If this low persists for at least 
one-half of a bit time, the start bit is assumed 
to be valid and the data input is then sampled at 
the middle of each bit time until the entire 
character, is assembled and placed in the Receive 
Data (UIOR) register. This method of detecting a 
start bit improves error rejection when noise 
spikes exist on an otherwise marking line. 

If XI clock mode is selected, bit synchronization 
must be accomplished externally, and the received 
data is sampled on the rising edge of the clock 
input. 

A received character can be read from the 8-bit 
Receive Data register (UIOR). The receiver 
inserts Is into the unused bits when a character 
length of other than eight bits is used. If 
parity is enabled, the parity bit is not stripped 
from the assembled character for character lengths 
less than eight bits; i.e., for lengths less than 
eight bits, the receiver assembles a character for 
the required number of data bits, plus a parity 
bit, wake-up bit, and Is for any unused bits, and 
places it in the UART Data register (UIO). 



MARKING LINE 



ik 



PARITY 

WAKE-UP START 



irTLK 



i 



PARITY 

WAKE-UP START 

4^ 



I 



* NOTES: 1 . Parity, wake-up, and second stop bit are optional 

2. Data can be anywhere from 5 to 8 bits ^ 

Figure 10-1 . Asynchronous Transmission Data Format 
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Since the receiver is buffered by one 8-bit 
register in addition to the Receive Data register, 
the CPU has enough time to service an interrupt 
and to accept the data character assembled by the 
UART. The receiver also has a buffer that stores 
error flags for each data character in the receive 
buffer. These error flags are loaded at the same 
time as the data character. 

After a character is received, it is checked for 
the following conditions: 

• If the received character is an ASCII control 
character, it sets the Control Character Detect 
(CCD) bit in the UART Receive Control (URC) 
register. (An ASCII control character is any 
character that has bits 5 and 6 cleared to 0.) 
It can also cause an interrupt if the Control 
Character Interrupt Enable (CCIE) bit in the 
UART Interrupt Enable (UIE) register is set to 
1. Once this bit is set, it remains set until 
cleared by software. 

• The wake-up settings are checked and any 
indicated action is completed. In wake-up 
mode, the CPU can be selectively interrupted on 
a match condition that includes all of the 
eight bits in the received character and a 
Wake-Up bit. The Wake-Up bit match and charac- 
ter match can be enabled simultaneously or 
individually. Each bit in this character match 
can also be masked individually, (For more 
discussion of this feature, see section 10.4.) 
Once this bit is set, it remains set until 
cleared by software. 



If parity is enabled, the Parity Error bit 
(PERR) in the UART Receive Control (URC) regis- 
ter is set to 1 whenever the parity bit of the 
character does not match the programmed 
parity. Once this bit is set, it remains set 
until cleared by software. 

The Framing Error bit (FERR) in the URC regis- 
ter is set to 1 if the character is assembled 
without any stop bits (i.e., a low level is 
detected for a stop bit) and it is set with the 
character on which it occurs. It stays latched 
until cleared by software. 

If the CPU fails to read a data character when 
more than one character has been received, the 
Receive Overrun Error bit (OVERR) in the URC is 
set to 1. When this occurs, the new character 
assembled replaces the previous character in 
the Receive Data register. With this arrange- 
ment, only the overwriting character is flagged 
with the Receive Overrun Error. Like the 
Parity Error bit, this bit can be cleared only 
by software command from the CPU. 



10.4 WAKE-UP FEATURE 

The Supers offers a powerful scheme to configure 
the UART receiver to interrupt only on certain 
special match conditions. Figure 10-2 shows the 
logic diagram for the scheme. 




ID 



1 



< 



l_. 

I 
I 



in 



Figure 10-2. Logic Diagram for Wake-Up Feature 
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The pattern match logic can be used with or with- 
out the Wake-Up bit. The Wake-Up Match register 
and Wake-Up Mask register determine the character 
or characters that will generate a pattern match 
when detected at the receiver. If the Wake-Up bit 
is enabled, the pattern match occurs if the 
Wake-Up bit in the received character matches a 
pre-determined value, and the received character 
matches the value(s) specified in the Wake-Up 
Match and Wake-Up Mask registers. If the Wake-Up 
bit is disabled, the pattern match depends only on 
the character's value. 

The Receive Data (UIOR) register is the receive 
buffer that is loaded if a new character is 
received and the previous character has been read 
by the CPU. The Wake-Up Match (WUMCH) register 
contains the match value. The Wake-Up Mask (WUMSK) 
register is used to mask out any selected bit 



UART 

positions in the WUMCH register. The Wake-Up 
Enable (WUENB) bit in the UART Transmit Control 
(UTC) register is enabled only if a match for the 
Wake-Up bit is also desired. If this is disabled, 
the scheme can still be used to look for a charac- 
ter match. The Receive Wake-Up Value (RWUVAL) bit 
in UART Mode A (UMA) register is the expected 
value of the Wake-Up bit; the Received Wake-Up bit 
(RWUIN) is the Wake-Up bit value received by the 
receiver. 

The following cases show how the Wake-Up Detect 
(WUD) bit in the UART Receive Control (URC) regis- 
ter can be set by a match condition. However, the 
CPU is interrupted only if the Wake-Up Interrupt 
Enable (WUIE) bit in the UART Interrupt Enable 
(UIE) register is set to 1. 



Case 1: NUENB r 1 (Wake-Up bit is envied) 

a) If Wake-Up bit match and WUMCH match (all 8 bits) is desired: 

Set WUMSK = 1111 1111 (%FF) 

WUMCH = (desired match value) 

If WUMCH (bits 7-0) = UIO (bits 7-0) and 
RWUVAL = RWUIN 

Then Wake-Up Detect (WUD) flag is set. 

b) If Wake-Up bit match and WUMCH match (selected bit, i.e., bits 
5, 4, 1, 0) is desired: 

Set WUMSK = 0011 0011 (%33) 

WUMCH = XX XX (desired match bits 5, 4, 1, 0) 

If WUMCH (bits 5, 4, 1, 0) = UIO (bits 5, 4, 1, 0) and 
RWUVAL = RWUIN 

Then Wake-Up Detect (WUD) flag is set. 

c) If only a Wake-Up bit match is desired: 

Set WUMSK = 0000 0000 (%00) 

WUMCH = XXXX XXXX (don't care) 

If RWUVAL = RWUIN 

Then Wake-Up Detect (WUD) flag is set. 



616 



UART 

Case 2: NUENB = (Vfoke-Up bit is ignored) 

a) If a match is desired for WUMCH (all 8 bits): 

Set WUMSK = 1111 1111 i%FF) 

WUMCH = (desired match value) 

If WUMCH (bits 7-0) = UIO (bits 7-0) 

Then Wake-Up Detect (WUD) flag is set. 

b) If a match is desired on WUMCH (selected bits only, i.e., bits 4, 3, 2): 

Set WUMSK = 0001 1100 («1C) 

WUMCH = XXX_ __XX (desired match bits 4, 3, 2) 

If WUMCH (bits 4, 3, 2) = UIO (bits 4, 3, 2) 

Then Wake-Up Detect (WUD) flag is set. 

c) If a match is always desired: 

Set WUMSK = 0000 0000 («00) 

WUMCH = XXXX XXXX (don't care) 

If this character is received, the Wake-Up Detect (WUD) flag is always 
set. However, this will be ignored if the Wake-Up Interrupt Enable 
(WUIE) bit in the UART Interrupt Enable (UIE) register is disabled. 



10.5 AUTO-ECHOAOOPBACK 

As shown in Figure 10-3, the UART can be configur- 
ed to automatically transmit any data coming in at 
the Receive Data input pin (P3q) RXD. This auto- 
echo mode of operation is enabled by setting the 
Auto-Echo (AE) bit in the UART Mode B (UMB) regis- 
ter to 1. In addition, the Transmit Data Select 
(TXDTSEL) bit in the UART Transmit Control (UTC) 



register must be set to 1 for this mode to work 
correctly. 

Similarly, the UART can be set in the local loop- 
back mode by setting the Loopback Enable (LBENB) 
bit in the UMB register to 1. In loopback mode, 
the output of the transmitter is automatically 
routed to the receiver. 



RECEIVE DATA (RxD) 



AUTO-ECHO 



•3 



TRANSMIT 
DATA SELECT 



5ELECT 



P31 DATA 



V 



AUTO-ECHO 
(AE)[UMB] 



-K 



r 



RECEIVE DATA IN (RxIN) 



LOOPBACK 

ENABLE 

[UMB] 



LOOPBACK 



O i ^ 



TRANSMIT DATA OUT (TxDATO) 



-TRANSMIT DATA (TxD) 
LBENB (TxDTSEL = 1) 



TRANSMITTER 



1 



RxD- 
■DcDATO - 

RxD- 
TxDATO - 



■-RxIN 
»RxlN 
>-RxlN 
•>RxlN 



TxDATO - 

TxDATO - 

RxD- 

RxD- 



► TxD 
►TxD 
►TxD 
^TxD 



Figure 10-3. Auto-Echo/Loopback 
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In auto-echo mode, the transmitter can still be 
enabled; however, the transmitter data goes 
nowhere unless loopback is also enabled. 

10.6 PflLLED OPERATION 

In a polled environment, the Receive Character 
Available (RCA) bit in the URC register must be 
monitored so the CPU can decide when to read a 
character. This bit is automatically cleared when 
the UIOR is read. 

To prevent overwriting data in polled operations, 
the transmit buffer status must be checked before 
writing to the transmit buffer (UIOT). The 
Transmit Buffer Empty (TBE) bit in the UTC is set 
to 1 after completing the sending of a character. 



10.7 BAUD-RATE GENERATOR 

The UART has its own on-chip programmable baud- 
rate generator implemented as a 16-bit down- 
counter. The transmitter can receive its clocking 
signal from an external source (P2i) or the baud- 
rate generator (BRG); the receiver clock can come 
from an external source (PZq) o^ *^^® on-chip 
baud-rate generator. 

If P2i is not used as a Transmit Clock input, it 
can be used to output the transmit clock, the CPU 
clock, the output of the baud-rate generator, or 
as an I/O line. 



The baud-rate, generator consists of two 8-bit Time 
Constant registers, a 16-bit downcounter, and a 
flip-flop on the counter's output that produces a 
square wave. 

On startup, the flip-flop is set to a high state, 
the value in the Time Constant registers is loaded 
into the Counter, and the Counter starts counting 
down. The output of the baud-rate generator 
toggles on reaching zero, the value in the Time 
Constant registers is again loaded into the 
Counter, and the process is repeated. The time 
constant can be changed at any^time, but the new, 
value does not take effect until the next load of 
the Counter. 

As shown in Figure 10-4, the output of the baud- 
rate generator can be used as the receive clock, 
the transmit clock, or both. The transmitter and 
receiver can handle data, at a rate of 1, 1/16th, 
1/32nd, or 1/64th of the clock rate supplied to 
the receive and transmit clock inputs. 

If P2i (Port 2, Bit 1) is not used as transmit 
clock input, it may be used as an output. A 
multiplexer (MUX) provided at P2i can be used to 
output various clocks or P2i data; bits 6 and 7 of 
the UMB register determine the function of P2 when 
it is used as an output. 



BAUD-RATE 
GENERATOR 



. 2 I S0UR( 



(BRG) 



II 



SOURCE (UMB) 



SYSTEM CLOCK 



(00) PORT 2 DATA 

(01) SYSTEM CLOCK 
.(10) 



RECEIVE CLOCK SELECT 
"(UMB) 

(-1) 



RECEIVE CLOCK DIVIDER 



M. 



4-16,32,64 

A. 



r 



CLOCK RATE (UMA) 



TRANSMIT CLOCK DIVIDER 

Tm) 
.transmit clock select 

(UMB) 



.(11) 



RECEIVER 
" CLOCK 



^TRANSMITTER 
CLOCK 



- CLOCK OUTPUT SELECT (UMB) 

Figure 10-4, Baud-Rate Generator 
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10.8 UART INTERFACE PINS 



10.9.2 Wake-Up Natch Register (WtJMCH) 



The UART uses up to four Port 2 and 3 pins for 
interfacing with the external world. These are: 



P20 


Receive Clock 


P'O 


Receive Data 


P2i 


Transmit Clock 


P3l 


Transit Data 



10.9 UART CONTROL/HODE AND STATUS REGISTERS 

The following sections and figures describe the 
UART Control/Mode and Status registers. 



Any character up to eight bits can be written into 
this register. The receiver detects a match 
between the received character and this charac- 
ter. The format of this register is shown in 
Figure 10-6. 



R254 BANK 1 (FE) WUMCH 
WAKE-UP MATCH REGISTER 



D7 De D5 D4 D3 



Di Do| 



- THIS BYTE, MINUS MASKED BITS, 
IS USED FOR WAKE-UP MATCH 



Figure 10-6. Wake-Up Match Register 



10.9.1 UART Data Register (UIOT & UIOR) 

k, 

Writing to this register automatically writes the 
data in the Transmit Data register (UIOT); a read 
from this register gets the data from the UART 
Receive Data register (UIOR). The format of this 
register is shown in Figure 10-5. 

R239 BANK (EF) UIO 

UART TRANSMIT DATA (WRITE) 

UART RECEIVE DATA (READ) 



D7 De D5 D4 D3 D2 Di Do 



10.9.3 Wake-Up Nask Register (WUNSK) 

Any bit in the WUMCH register can be masked by 
writing a into the corresponding bit in this 
register. The format of this register is shown in 
Figure 10-7. 



R255 BANK 1 (FF) WUMSK 
WAKE-UP MASK REGISTER 



El 


[^ 


Ds 


D4 


D3 


D2 


Di 


Do 















- DATA (Do = LSB) 



THESE BITS CORRESPOND TO BITS 
IN WAKE-UP MATCH REGISTER; Os 
MASK CORRESPONDING MATCH BITS 



Figure 10-5. UART Data Register 



Figure 10-7. Wake-Up Mask Register 



10.9.4 UART Receive Control Register (URC) 

The fields in this register (Figure 10-8) are: 

RCA. Receive Ctiaracter Available (Dq). This is a 
status bit that is set to a 1 when data is avail- 
able in the receive buffer (UIOR). When the CPU 
reads the receive buffer, it automatically clears 



this bit to 0. A write to this bit position has 
no effect. A hardware reset forces this bit to 0. 

RENB. Receive Enable (D^). When this bit is set 
to 1, the receive operation begins. This bit 
should be set only after all other receive para- 
meters are established and the receiver is com- 
pletely initialized. This bit is cleared to a by 
a hardware reset, which disables the receiver. 



1 = WAKE-UP DETECT 

= CONTROL CHARACTER DETECT 

1 = BREAK DETECT 

1 = FRAMING ERROR 



J 



R236BANK0(EC)URC 
UART RECEIVE CONTROL 



dH 



L, 



RECEIVE CHARACTER AVAILABLE 
1 = RECEIVE ENABLE 
1 = PARITY ERROR 
1 = OVERRUN ERROR 



Figure 10-8. UART Receive Control Register 
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PERR. Parity Error (D2). This is a status bit. 
When parity is enabled, this bit is set to 1 and 
buffered with the character whose parity does not 
match the programmed parity (even/odd). This bit 
is latched so that once an error occurs, it 
remains set until it is cleared to by writing a 
1 to this bit position. A hardware reset forces 
this bit to 0. 

OVERR. Overrun Error. (O3). This status bit indi- 
cates that the receive buffer has not been read 
and another character has been received. Only the 
character that has been written over is flagged 
with this error; once set, this bit remains set 
until cleared to by writing a 1 to this bit 
position. A hardware reset forces this bit to 0. 

FERR, FrMing Error (Q4). This is a status bit. 
If a framing error occurs (no stop bit where 
expected) , this bit is set for the receive charac- 
ter in which the framing error occurred. This bit 
remains set until cleared to by writing a 1 to 
this bit position. A hardware reset forces this 
bit to 0. 



to this bit position. A hardware reset forces this 
bit to 0. See note in section 10.9.5 for .more 
information. 

ceo* Control Character Detect (Dg)« This status 
bit is set any time an ASCII control character is 
received in the receive data stream. It stays set 
until cleared to by writing a 1 to this bit 
position, (An ASCII qontrol character is any 
character that has bits 5 and 6 set to 0.) A hard- 
ware reset forces this bit to 0. 

IIUD« Wake^-Up Detect (Dy). This status bit is set 
any time a valid wake-up condition is detected at 
the receiver. It stays set until cleared to by 
writing a 1 to this bit position. The wake-up 
condition can be satisfied in many possible ways 
by the Wake-Up bit, Wake-Up Match register, and 
Wake-Up Mask register. See the Wake-Up Feature 
section (section 10.4) for a more detailed explan- 
ation. A hardware reset forces this bit to 0. 



10.9.5 UART Interrupt Enable Register (UIE) 



BRKD. Break Detect (D5). This is a status bit 
that is set at the beginning and the end of a 
break sequence in the receive data stream. It 
stays set to 1 until cleared to by writing a 1 



This register contains the individual status and 
data interrupt enables (Figure 10-9). The fields 
in this register are; 



R237 BANK (ED) UIE 
UART INTERRUPT ENABLE 



I D? I D6 



D5 



D3 



Dl Do 



1 = WAKE-UP INTERRUPT ENABLE 

1 = CONTROL CHARACTER - 
INTERRUPT ENABLE 
1 = BREAK INTERRUPT ENABLE - 

1 = RECEIVE ERROR INTERRUPT - 
ENABLE 



J 



L. 



RECEIVE CHARACTER AVAILABLE 
INTERRUPT ENABLE 
RECEIVE DMA ENABLE 



- 1 = TRANSMIT INTERRUPT ENABLE 

- 1 = ZERO COUNT INTERRUPT ENABLE 



Figure 10-9. UART Interrupt Enable Register 



RCAIE. Receive Character Available Interrupt 
Enable (Oq). If this bit is set to 1, then a 
Receive Character Available status in the URC 
register will cause an interrupt request. In a 
DMA receive operation, if this bit is set to 1, 
then an interrupt request will be issued only if 
an End-of-Process (EOP) of the DMA counter is also 
set. If it is not set, a Receive Character 
Available status causes no interrupt. A hardware 
reset forces this bit to 0. 

ROMAEIMB* Receive DMA Enable (Di). When this bit 
is set to 1 , the DMA function is enabled for the 
UART receiver. Whenever a Receive Character 
Available signal in the URC register is true, a 
DMA request will be made. When the DMA channel 
gains control of the bus, it will transfer the 



received data to the register file or the external 
memory. A hardware reset forces this bit to 0. 

TIE. Transmit Interrupt Enable (D2). If this bit 
is set to 1, then a Transmit Buffer Empty signal 
in the UTC register will cause an interrupt 
request. In a DMA transmit operation, if this bit 
is set to 1, then an interrupt request will be 
issued only if an End-of-Process (EOP) of the l>1A 
counter is also set. If it is not set, a Transmit 
Buffer Empty signal causes no interrupt. A 
hardware reset forces this bit to 0. 

ZCIE. Zero Count Interrupt Enable (O5). If this 
bit is set to 1 , a baud-rate generator Zero Count 
status in the UTC register will cause an interrupt 
request. A hardware reset forces this bit to 0. 
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REIE. Receive Error Interrupt Enable (04). If 

this bit is set to 1 , any receive error condition 
will cause an interrupt request. Possible receive 
error conditions include parity error, overrun 
error, and framing error. A hardware reset forces 
this bit to 0. 

BRKIE« Break Interrupt Enable (O3). If this bit 
is set to 1 , a transition in either direction on 
the break signal will cause an interrupt request. 
A hardware reset forces this bit to 0. 



CCIE* Control Character Interrupt Enable (Dg). If 

this bit is set to 1, then an ASCII Control 
Character Detect signal in the URC register will 
cause an interrupt. A hardware reset forces this 
bit to 0. 

NUIE. Wake<4Jp Interrupt Enable (D7). If this bit 
is set to 1, then any of the wake-up conditions 
that set the Wake-Up Detect bit (WUD) in the URC 
register will cause an interrupt request. A hard- 
ware reset forces this bit to 0. 



Note: A break signal is a sequence of Os*. When 
all the required bits, parity bit, wake-up 
bit, and stop bits are Os, the receiver 
immediately recognizes a break condition (not 
a framinq error) and causes Break Detect 
(BRKD) to be set and an interrupt request. At 
the end of the break signal, a zero character 
is loaded into the Receive Data register 
(UIOR) and Break Detect (BRKD) is set again, 
along with another interrupt request. 



10.9.6 UART Node A Register (UNA) 

This register controls the configurations of the 
receiver/transmitter that are not likely to change 
on a dynamic basis. The fields in this register 
(Figure 10-10) are: 



R250 BANK 1 (FA) UMA 
UART MODE A 



Dy De D5 D4 D3 D2 Di Do 



CLOCK RATE 
P7D6 
=X1 

1 =X16 

1 =X32 
11 = X64 



zr 



BITS PER CHARACTER - 
D5D4 

0=5 BITS 
1 =6 BITS 
10=7 BITS 
11=8 BITS 



L 



TRANSMIT WAKE-UP VALUE 
RECEIVE WAKE-UP VALUE 
1 = EVEN PARITY 
1 = PARITY ENABLE 



Figure 10-10. UART Mode A Register 



mJVAL. Transmit Wake-Up Value (Dq). If the 

wake-up mode is enabled, then the value in this 
bit position is transmitted along with the charac- 
ter at the appropriate time by the transmitter. 

RMUVAL. Receive Wake^p Value (D^). If the wake- 
up mode is enabled, then the receiver expects a 
wake-up bit after the parity bit in the incoming 
data stream and the value is compared with this 
bit value. For further explanation of how this is 
used, see the Wake-Up Feature section (Section 
10.4). 

CVNPAR. Even Parity (O2). This bit determines the 
type of parity used by both the receiver and the 



transmitter. If this bit is set to 0, odd parity 
is used; if this bit is set to 1 , then even parity 
is used. If the Parity Enable (PARENS) bit in thia 
register is not enabled, then this bit has no 
effect. 

PAREhB. Parity Enable (03). When this bit is set 
to 1 , an additional bit position beyond those 
specified in the bits/character control is added 
to the transmitted data and is expected in the 
received data. The received parity bit is trans- 
ferred to the CPU as a part of the data unless 
eight bits per character are used. If this bit is 
set to 0, the parity feature is disabled. 
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BPC1, BPCO. Bits Per Character (D5, D4). This 
field determines the number of bits per character 
for both the transmit and the receive sections. 
The character bits are right-justified with the 
least significant bit transmitted or received 
first. The field is coded as shown in Table 
10-1. 

Table 10-1. Character Size F;ield Encoding 

D5 D4 Character Size in Bits 












1 


1 





1 


1 



CR1, CRO» Clock Rate (O7, D^). This field 
specifies the multiplier between the clock and the 
data rates. Table 10-2 shows how this field is 
coded. 

T^le 10-.2. aock Rate Field Encoding 



D7 D5 Node 









1 X 





1 


16 X 


1 





32 X 


1 


1 


64 X 



Description 



Clock rate = 1 x data rate 
Clock rate = 16 x data rate 
Clock rate = 32 x data rate 
Clock rate = 64 x data rate 



R235BANK0(EB)UTC 
UART TRANSMIT CONTROL 



Dr De 



Ds 



Di Do 



TRANSMIT DATA SELECT: 

= OUTPUT P3i DATA 

= OUTPUT TRANSMIT DATA 



J 



STOP BITS: - 
= 1 STOP BIT 
1 = 2 STOP BITS 

1 = WAKE-UP ENABLE - 





1 1 

1 



TRANSMIT DMA ENABLE 
TRANSMIT BUFFER EMPTY 
1 = ZERO COUNT 

TRANSMIT ENABLE 



Figure 10-11. UART Transmit Control Register 



10.9.7 UART TransHit Control Register (UTC) 

This register contains the status and command bits 
needed to control the transmit section of the 
UART. The fields in this register (Figure 10-11) 
are: 

TOHAENB. Transmit DHA Enable (Dg). When this bit 
is set to 1 , it enables the DMA function for the 
UART transmit section. If this bit is set and the 
Transmit Buffer Empty signal becomes true, then a 
DMA request is made. When the DMA channel gains 
control of the bus, it transfers bytes from the 
external memory or the register file to the UART 
transmit section. A hardware reset forces this 
bit to 0. 

TBE. TransMit Buffer Empty (D^). This status bit 
is set to 1 whenever the transmit buffer is 
empty. It is cleared to when a data byte is 
written in the transmit buffer. A hardware reset 
forces this bit to 1 . 

2C* Zero Count (D2). This status bit is set to 1 

and latched when the Counter in the baud-rate 
generator reaches the count of 0. This bit can be 
cleared to by writing a 1 to this bit position. 
A hardware reset forces this bit to 0. 



TENB, Transmit Enable (Oj). Data is not 
transmitted until this bit is set to 1. When 
cleared to 0, the Transmit Data pin continuously 
outputs Is unless Auto-Echo mode is selected. 
This bit should be cleared only after the desired 
transmission of data in the buffer is completed. 
A hardware reset forces this bit to 0. 

IIUE^B. Wake-Up Enable (D4). If this bit is set to 
1, wake-up mode is enabled for both the transmit- 
ter and the receiver. The transmitter adds a bit 
beyond those specified by the bits/character and 
the parity. This added bit has the value specified 
in the Transmit Wake-Up Value (TWUVAL) in the UMA 
register. The receiver expects a Wake-Up bit 
value in the incoming data stream after the parity 
bit and compares this value with that specified in 
the Received Wake-Up Value (RWUVAL) bit in the UMA 
register. The resulting action depends on the 
configuration of the Wake-Up feature. A more 
complete description is given in the Wake-Up 
Feature section (section 10.4). A hardware reset 
forces this bit to 0. 

STPBTS. Stop Bits (D5). This bit determines the 
number of stop bits added to each character trans- 
mitted from the UART transmit section. If this bit 
is a 0, then one stop bit is added. If this bit 
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is a 1y then two stop bits are added. The 
receiver always checks for at least one stop bit, 
A hardware reset forces this bit to 0. 

SCNBRK. 'Send Break (D5). When set to 1, this bit 
forces the transmit section to continuously output 
Os, beginning with the following transmit clock, 
regardless of any data being transmitted at the 
time. This bit functions whether or not the 
transmitter is enabled. When this bit is cleared 
to 0, the transmit section continues to send the 
contents of the Transmit Data register. A hard- 
ware reset forces this bit to 0. 

TXDTSEL. Transmit Data Select (O7). This bit has 
an effect only if port pin P3i is configured as an 



output. If this bit is set to 1, the serial data 
coming out of the transmit section is reflected on 
the P3i pin. If this bit is set to 0, then P3>| 
acts as a normal port and P3>| data is reflected on 
the P3i pin. A hardware reset forces this bit to 
0. 



10.9.8 UART Node B Register (UHB) 

This register (Figure 10-12) contains the neces- 
sary status and command bits for the baud-rate 
generator, transmit clock select, auto-echo and 
loopback enable. The fields are as follows: 



R251 BANK 1 (FB) UMB 
UART MODE B 



Ds 



CLOCK OUTPUT SELECT 

D7D6 

= P2i DATA 

1 = SYSTEM CLOCK (XTAL/2) 

1 = BAUD-RATE GENERATOR 

OUTPUT 
1 1 = TRANSMIT DATA CLOCK 



3 



1 = AUTO-ECHO - 

RECEIVE CLOCK INPUT SELECT: - 

= P2o 

1 = BAUD-RATE GENERATOR 

OUTPUT 



L. 



LOOPBACK ENABLE 
BAUD-RATE GENERATOR ENABLE 



• BAUD-RATE GENERATOR SOURCE: 

= P2o (EXTERNAL) 

1 = INTERNAL (XTAL/4) 



TRANSMIT CLOCK INPUT SELECT: 

= P2i 

1 = BAUD-RATE GENERATOR OUTPUT 



Figure 10-12. UART Mode B Register 



LBENB. Loopback Enable (Og). Setting this bit to 
1 selects the local loopback mode of operation. In 
this mode, the data output from the transmit 
section is also routed back to the receive 
section. For meaningful results, the frequency of 
the transmit and receive clocks must be the same. 
A hardware reset forces this bit to 0, 

BRGENB, Baud-Rate Generator Enable (D^). This bit 
controls the operation of the baud-rate genera- 
tor. The Counter in the baud-rate generator is 
enabled for counting when this bit is set to 1 and 
disabled for counting when this bit is set to 0. 
A hardware reset forces this bit to 0. 

B^GSRC. Baud-Rate Generator Source (02). This bit 
selects the source of the clock for the baud-rate 
generator. If this bit is set to 0, the baud-rate 
generator clock comes from the receive clock pin 
(PZq). If this bit is set to 1, the clock for the 
baud-rate generator is the CPU clock divided by 
two (XTAL clock divided by four). A hardware reset 
forces this bit to 0. 



TCIS. Transmit Clock Input Select (D3). This bit 
selects the source for the transmit section clock 
input. If TCIS is cleared to 0, the source is the 
transmit clock pin (P2^). If it is set to 1, then 
the source is the baud-rate generator output. A 
hardware reset forces this bit to 0. 

RCIS* Receive Clock Input Select (04). This bit 
selects the source for the receive section clock 
input. If this bit is cleared to 0, the source is 
the receive clock pin (P2o). If it is set to 1, 
then the source is the baud-rate generator out- 
put. A hardware reset forces this bit to 0. 

AE* Auto-Echo (03). Auto-echo mode of operation 
is enabled by setting this bit to 1 . In this 
mode, the data coming in on the receive data pin 
is reflected out on the transmit data pin. The 
receive section still listens to the receive data 
input; however, the data from the transmit section 
goes nowhere. See section 10.6 for a more detail- 
ed description of this function. A hardware reset 
forces this bit to 0. 
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C0S1, COSO. Clock Output Select (D7-O5). This 
field determines the source that drives the 
transmit clock pin if P2i is configured as an 



output. A hardware reset forces this field to 
00. Table 10-3 shows the coding of this field. 



Table 10>3. Transmit Clock Source Field Encoding 



D7 Dg Output Source 



P2<) Data 

System clock (XTAL frequency divided by 2) 

Baud-rate generator output 

Transmit data rate 












1 


1 





1 


1 



10.9.9 UART Baud>Rate Generator Tine Constant 
Register (UBG) 



value does not take effect until the next time 
constant is loaded into the downcounter. 



This register contains the high and low bytes 
(Figure 10-13) for the 16-bit time constant used 
to generate the desired baud rate. The time 
constant can be changed at any time, but the new 



The formula for determining the appropriate time 
constant for a given baud rate is shown below, 
with the desired rate in bits per second and the 
baud-rate clock period in seconds. 



1 



time constant 



-1 



(2 X baud rate x n x BRG input clock period) 
where n=1,16,32,or 64 x the clock rate selected in UMA register R250 



R248 BANK 1 (F8) UBGH 
UART BAUD-RATE GENERATOR 



R249 BANK 1 (F9) UBGL 
UART BAUD-RATE GENERATOR 
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LOW BYTE (UBG0-UBG7) 



Figure 10-13. UART Baud-Rate Generator Time Constant Register 



RECEIVE CLOCK SELECT 
(UMB) 

(-1) 




(00) PORT 2 DATA 

(01) SYSTEM CLOCK 
.(10) 



(-1) 
TRANSMIT CLOCK SELECT 
(UMB) 



(11) 



- CLOCK OUTPUT SELECT (UMB) 



Figure 10-14 . Baud-Rate Generator 
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Chapter 1 1 
DMA Channel 



11.1 INTRODUCTION 

The Supers has dn on-chip Direct Memory Access 
(DMA) channel to provide high bandwidth data 
transmission capabilities that can be used by the 
DART receive or transmit section or by Handshake 
Channel 0. 

The DMA channel can transfer data between the 
peripheral device and contiguous locations in 
either the register file or external data memory. 



The DMA Count registers (R240 and R241 , Bank 1) 
hold the 16-bit count that determines the number 
of transactions the DMA channel is to perform. The 
count loaded should be n-1 to perform n byte 
transfers. An interrupt can be generated when the 
count is exhausted. 

DMA transfers to or from the register file take 

six CPU clock cycles; DMA transfers to or from 

memory take ten CPU clock cycles, excluding wait 
states. 



UART Receiver > Register file or 

data memory 

UART Transmitter < Register file or 

data memory 

Handshake Channel < Register file or 

data memory 

Handshake Channel > Register file or 

data memory 

Prior to enabling the DMA channel, the starting 
register address for the block to be transferred 
must be present in register C1j^ or the starting 
memory address must be present in register C0|^ 
(high byte) and d^ (low byte). Registers CO^ 
and C^^ themselves can only be accessed as part 
of the working register group. The address is 
auto-incremented after each DMA-controlled 
transfer. 



11.2 DHA CONTROL REGISTERS 

The control bits that link the DMA channel to the 
UART or an I/O port are the Transmit DMA Enable 
(TOMAENB) bit in the UART Transmit Control (UTC) 
register for the transmitter, the Receive DMA 
Enable (RDMAENB) bit in the UART Interrupt Enable 
(UIE) register for the receiver, and the DMA 
Enable bit (D2) in the Handshake Control regis- 
ter for the I/O ports. Only one of these three 
enable bits should be set at a given time. If 
Handshake Channel is linked to the DMA channel, 
the data transfer direction is determined by the 
direction of the handshake. 

A bit in the External Memory Timing register, 
called DMA INT/EXT, controls whether DMA transfers 
access the register file or external data memory. 
When this bit is cleared to 0, transfers are to/ 
from the register file. When this bit is set to 
1, transfers are to/from external data memory. 
See Figure 11-1. 



R254 (BANKO) EMT 
EXTERNAL MEMORY TIMING REGISTER 



D7 De D5 D4 D3 D2 



Do 
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= EXTERNAL MEMORY 
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R240(BANK1)DCH 
DMA COUNT HIGH 
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Figure 11-1. DMA Control Registers 
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11.3 DMA AND THE UART RECEIVER 

The Receive DMA Enable bit (RDMAENB) in the UIE 
register (R237) of the UART is first set to 1 to 
link the DMA to the UART receiver. 

Data received at the UART receiver is handled by 
the DMA as soon as the Receive Character Available 
(RCA) status bit of the URC register (R236) of the 
UART is set to 1 . The DMA reads data from the 
UIO register of the. UART and then clears the RCA 
bit to prepare the UART receiver to receive new 
data. The data is then stored at the location 
whose address is contained in the DMA address reg- 
ister (RR192). The DMA count at RR240, Bank 1, is 
decreased by 1 and the TM^ address register is in- 
creased by 1. When the DMA count is negative, an 
interrupt request (IRQ6, vector address 20, 21) is 
generated at the UART Receive section if the 
Receive Character Available Interrupt Enable bit 
of the UIE register of the UART (R237) is set to 
1. 



Upon transmit, the Transmit Buffer Empty status 
bit (TBE) in the UTC register (R?35) of the UART 
is set to 1. The DMA then transfers the data at 
the location whose address is contained in the DMA 
address register (RR192) to the UIO register 
(R239) of the UART. 

The TBE bit is then cleared to 0. The DMA count 
at RR240, Bank 1, is decreased by 1 and the DMA 
address register is increased by 1. When the DMA 
count is negative, the DMA issues an End-of- 
Process (EOF) signal to the UART. The UART grants 
an interrupt request (IRQI, vector address 26, 27) 
to the Supers if the Transmit Interrupt Enable 
(TIE) bit of the UIE register (R237) of the UART 
is set to 1 . 

The UART transmitter continues its operation with 
the new data in the UIO register and the DMA re- 
sponds to the TBE bit as described above until an 
interrupt is generated due to a negative DMA 
count. 



The UART continues to receive new data and the DMA 
responds to the RCA bit as described above until 
an interrupt is generated due to a negative DMA 
count . 

11.4 DNA AND IHE UART TRANSHITTER 

First, the Transmit DMA Enable (TDMAENB) bit of 
the UTC register (R235) of the UART is enabled to 
link the DMA to the UART transmitter. 



11.3 DNA AND HANDSHAKE CHANNEL 

The DMA can be configured with Handshake Channel 
to transfer data from register file or data memory 
to I/O devices or vice versa through Port 1 or 
Port 4. Handshake Channel can be in either 
fully interlocked mode or strobed mode as con- 
trolled by the Handshake Control register 
(R244). The direction of DMA transfer is deter- 
mined by the handshake direction, which is the 
direction of the chosen port. 



11.5.1 DNA WRITE (INPUT HANDSHAKE CHANNEL 0) 

The 1/0 device transfers data to register file or 
data memory through Handshake Channel and the 
DMA channel. 
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The Handshake Channel Enable and DMA Enable bits 
of the Handshake Control (HOC) register (R244) 
should be first set to 1 , When the I/O device 
puts data on the port specified in the HOC regis- 
ter and activates T5R? to go from high to low as in 
Figures 8-11 and 8-13, the DMA transfers data on 
the port to the specified address in the DMA 
address register (RR192). The DMA count at RR24Q, 
Bank 1, is decreased by 1 and the DMA address reg- 
ister is increased by 1. When the DMA count is 
negative, the DMA issues an End-of-Process (EOP) 
signal to Handshake Channel 0. Handshake Channel 
grants an interrupt request (IRQ4) to the 
Supers. The handshake output at pin 25 is the 
same as described in Figures 8-11 and 8-13 and the 
DMA is waiting for the I/O device to put data on 
the port and activate the T5SV signal again. 



11.5.2.1 FULLY INTERLOCKED MODE 

At State 3 of Figure 8-12, the DMA reads the data 
at the address specified in the DMA address regis- 
ter (RR192) and transfers it to the port. The DMA 
cour)t at RR240, Bank 1, is decreased by 1 and the 
DMA address register is increased by 1. When the 
DMA count is negative, the DMA issues an End-of- 
Process (EOP) signal to Handshake Channel 0. 
Handshake Channel then grants an interrupt re- 
quest (1RQ4) to the SuperS. 

The DMA and handshake process continues as in 
Figure 8-12 until an interrupt is caused by a 
negative DMA count, 

11.5.2.2 STROBED MODE 



11.5.2 DNA READ (OUTPUT HANDSHAKE CHANNEL 0) 

Data is transferred from register file or data 
memory to the I/O device through the DMA channel 
and Handshake Channel 0. 

The Handshake Channel Enable and DMA Enable bits 
of the Handshake Control (HOC) register (R244) 
should be first set to 1 , The handshake direction 
should be set by choosing the direction of the 
port specified in the HOC register. 



After the first writing of the first byte of data 
to the port as in Figure 8-14, the DMA is activat- 
ed at the end of strobe time. The DMA reads the 
data at the address specified in the DMA address 
register (RR192) and transfers it to the port. 
The DMA count at RR240, Bank 1, is decreased by 1 
and the DMA address register is increased by 1. 
When the DMA count is negative, the DMA issues an 
End-of-Process (EOP) signal to Handshake Channel 
0. Handshake Channel then grants an interrupt 
request (IRQ4) to the SuperS. 



The DMA sequence should always begin by writing 
the first byte of data to the port to start the 
DMA. This is an important process, otherwise the 
DMA is not activated when Handshake Channel is 
not yet activated. The DMA starting address in 
the DMA address register (RR192) should now be set 
at the second byte of the data block. The I/O de- 
vice should then read that first byte of data and 
store it away as in Figures 8-12 and 8-14. The 
DMA is then activated. 



The handshake operation continues as in Figure 
8-14 and the DMA transfers new data to the port 
only at the end of strobe time. The DMA ?tops 
when an interrupt is activated by a negative DMA 
count . 
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Figure 11-2. Interrupts and the DMA 
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Chapter 12 
External Interface 



12.1 INTRODUCTION 

The 48-pin SuperB has 40 programmable I/O pins, 
some of which are configurable as an external 
memory interface, A description of the pins and 
their functions follows (see Figure 12,-1). 



12.2 PIN DESCRIPTIONS 

TSSm Address Strobe (output, active Iom, 3~state). 

K§* is pulsed low once at the beginning of each 
machine cycle. For external memory accesses, the 
rising edge of T^ indicates that addresses, R/W, 
and PRf signals are valid. Under program control, 
7^ can be placed in a high impedance state along 
with Ports and 1, 15^, R/W, and M if used. 

15?. Data Strobe (output, active low, 3-state). 

D5*, provides timing for data movement to or from 
Port 1 for each external memory transfer. During a 



write cycle, data out is valid at the leading edge 
of 05"; during a read cycle, data in is valid prior 
to the trailing edge of DS*. DS* can be placed in a 
high-impedance state along with Ports and 1 , 
7^, R/W, and Wi if used. 

R/W. Read/Write (output, 3-.state). R/¥ deter- 
mines the direction of data transfer for external 
memory transactions. R/W is low during write 
operations and high during all other operations. 
R/W can be placed in a high-impedance state along 
with Ports and 1, ^, 05*, and W{ if used. 

PO^POy, P1o-Pl7, PZo-IPZ?. P3irP57» P4|rP*7- I/O 
Port Lines (inputs/outputs, TTL-conpatible) • 

These I/O lines provide five 8-bit I/O ports that 
can be configured under program control for I/O or 
external memory interfacing. Ports and 1 can be 
placed in a high- impedance state under program 
control, along with ^, SS", R/W, and Wi if used. 
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Figure 12-1 \ Pin Functions and Assignments 
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RESET. Reset (input , active low). RESrt is used 
to initialize the SuperS. When RESET is 
deactivated, program execution begins from program 
address 0020|^. ReSeI is also used to enable the 
Supers test mode. 



XTAL1, XTAL2. Crystal (oscillator input/output). 

XTAL1 and XTAL2 are used to connect a parallel 
resonant crystal or external clock source to the 
on-board clock oscillator and buffer. 



12.3 CCMFIGURING FOR EXTERNAL HEMORY 

Before external memory can be referenced in a 
ROM-based part, Ports and 1 must be properly 
configured. The minimum bus configuration uses 
Port 1 as a multiplexed address/data bus (ADg-ADy) 
with access to 256 bytes of external memory. In 
this configuration, the eight lower order address 
bits (Ag-Ay) are multiplexed with the eight data 
bits (Dg-Dy). 

Additional address lines can be output on the Port 
pins, where bit of that port corresponds to 
A3, bit 1 to A9, and so on. The pins of Port 
can be defined as memory address lines or I/O 
lines on a bit-by-bit basis, via programming of 
the Port Mode register (R240, Bank 0), This 
ensures the efficient use of the I/O pins, allow- 
ing the Supers to address various sizes of 
external memory using no more pins than neces- 
sary. Port pins not configured for address 
lines can be used as I/O lines. 

Configuring Port 1 for external memory is accom- 
plished by writing the appropriate bits in the 
Port Mode register, R241 in Bank (Figure 12-2). 





R241BANK0(F1)PM 
PORT MODE REGISTER 
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00 = OUTPUT 

01 = INPUT 
1X = AD0-AD7 



Figure 12-2. Configuring Port 1 for External Memory 
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Figure 12-3. Configuring Port for External Memory 



Configuring Port for external memory is accom- 
plished in a similar manner, using Port Mode 
Register, R240 in Bank (Figure 12-3). 

Once Port 1 is configured ds an address/data port, 
it is no longer usable as a general-purpose 1/0 
port. Attempting to read Port 1 returns "FF|^"; 
writing has no effect. Similarly, if Port is 
configured for address lines A8-A15, it is no 
longer usable as a general-purpose I/O port; how- 
ever, if not all of the bits are defined as 
address lines, the remaining bits are still 
accessible as an I/O port. Reading Port will 
return the port data in those positions defined as 
I/O. The positions defined as address will return 
the value on the external pins which, under normal 
loading, will be the address. 



After* setting the modes of Ports and 1 for 
external memory, the next three bytes must be 
fetched from internal memory. 



An external memory interface may be 3-stated under 
program control by setting bit 7 of the System 
Mode register, R222 (Figure 12-4). 



R222 (DE) SYM 
SYSTEM MODE REGISTER 



\Dy 



D3 



Do 



T_ 



- 3-STATE EXTERNAL MEMORY INTERFACE 



Figure 12-4. 3-State External Memory Interface 

When this bit is set to 1, the external memory 
interface, including AS, DS, R/iJ and DM, is 3-stated. 
A hardware reset forces this bit to a 0. The external 
memory interface can but should not be tri -stated in 
the ROM less parts. 

In Supers parts with on-chip ROM, a hardware reset 
configures Ports and 1 as input ports and 
instruction execution begins at location 0020j^, 
which is within the on-chip ROM. 

In the ROMless parts, a hardware reset configures 
Port pins POg-PO^ as address out and pins 
PO5-PO7 as inputs; Port 1 is configured as an 
address/data port, allowing access to 8 Kbytes of 
memory. If external memory greater than 8 Kbytes 
is desired, additional address lines must be 
configured in Port 0. Since Port lines are 
initially configured as inputs, they will float 
and their logic state will be unknown until an 
initialization routine is executed that configures 
Port 0. This initialization routine must reside 
within the first 8 Kbytes of executable code and 
must be physically mapped into memory by 
externally forcing the Port address lines to a 
known state. 



629 



External Interface 



12.4 EXTERNAL STACKS 



12.3 DATA NENORY 



The Supers architecture supports stack operations 
in either the register file or in data memory. A 
stack's location is determined by setting bit 1 in 
the External Memory Timing register, R254, Bank 
(Figure 12-5). 

R254BANK0(FE)EMT 
EXTERNAL MEMORY TIMING 



IE 



03 



Do 



Tl 



- STACK SELECTION 

= REGISTER FILE 

1 = DATA MEMORY 



Figure 1 2-5. External Memory Timing 

The instruction used to change the stack selection 
bit should not be immediately followed by an 
instruction that uses the stack, since this will 
cause indeterminate program flow. Interrupts 
should be disabled when changing 4^he stack 
selection bit. 



The two external memory spaces, data and program, 
can be addressed as a single memory space or as 
two separate spaces. If the memory spaces are 
separated, program memory and data memory are 
logically selected by the Data Memory select out- 
put (CW). OR is made available on Port 3, line 5 
(P35) by setting bit D3 in the fort Mode register 
to 1 (Figure 12-6). 

R241BANK0(F1)PM 
PORT MODE REGISTER 



I D7 De Ds D4 D3 D2 Di Do I 



T_ 



= P3s MODE DETERMINED BY PORT 2/3 

C MODE REGISTER 

1 = PSg = DM OUTPUT 



Figure 12-6. Data Memory 



12.6 BUS OPERATION 

Typical data transfers between the SuperB and 
external memory are illustrated in Figures 12-7 
and 12-8. Machine cycles can vary from six to 
twelve external clock periods depending on the 
operation being performed. The notations Used to 
describe the basic timing periods of the SuperB 



are machine cycles (Mn), timing states (Tn), and 
clock periods. All timing references are made 
with respect to the output signals T^S and 155*. The 
clock is shown for clarity only and does not have 
specific timing relationships with other signals; 
the clock signal shown is the external clock, 
which has twice the frequency of the internal CPU 
clock. 
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Figure 12-7. External Instruction Fetcli or Memory Read Cycle 
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Figure 12-8. External Memory Write Cycle 



12.6.1 Address Strobe OS) 

All transactions start with Address Strobe iW) 
being driven low and then raised high by the 
Supers. The rising edge of 755* indicates that 
Read/Write XR/W), Data Memory (PR), and the 
addresses output from Ports and 1 are valid. 
The addresses output via Port 1 typically need to 
be latched during 7^, whereas Port address 
outputs y if used, remain stable throughout the 
machine cycle. 



12.6.2 Data Strotie (BS) 

The SuperB uses Data Strobe (1550 to time the 
actual data transfer. For write operations (R/W = 
low) , a low on BS* indicates that valid data is on 
the Port 1 ADg-ADy lines. For read operations 
(R/W = high), the address/data bus is placed in a 
high- impedance state before driving ISS* low so that 
the addressed device can put its data on the bus. 
The Supers samples this data prior to raising 155* 
high. 



12.6.3 External Henory Operations 

Whenever the SuperS is configured for external 
memory operations, the addresses of all internal 



program memory references appear on the external 
bus. This should have no effect on the external 
system since the bus control line 155* remains in 
its inactive high state, 155* becomes active only 
during external memory references. 



12.7 EXTENDED BUS TIMING 

The Supers can accommodate slow memory access and 
cycle times by three different methods that give 
the user much flexibility in the types of memory 
available. 



12.7.1 Software Programable Wait States 

The Supers can stretch the Data Strobe (135) timing 
automatically by adding one, two, or three 
internal clock periods. This is under program 
control and applies only to external memory 
cycles. Internal memory cycles still operate at 
the maximum rate. The software has independent 
control over stretched Data Strobe for external 
memory (i.e., the software can set up one timing 
for program memory and a different timing for data 
rpemory). Thus, program and data memory may be 
made up of different kinds of hardware chips, each 
requiring its own timing. 
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12.7.2 Slow Memory Timing 

Another feature of the SuperS that is useful in 
interfacing with slow memories is the Slow Memory 
Timing option. When this option is enabled, the 
normal external memory timing is slowed by a 
factor of two (bus clock = CPU clock divided by 
two). All memory times for set-up, duration, 
hold, and access times are essentially doubled. 
This feature can also be used with the programmed 
automatic wait states described above. Programmed 
wait states can still be used to stretch the Data 
Strobe time by one, two, or three internal clock 
times (not two, four, or six) when Slow Memory 
Timing is enabled. 



12.7.3 Hardware Wait States 



All of the extended bus timing features are 
programmed by writing the appropriate bits in the 
External Memory Timing register (Figure 12-9). 



R254 BANKO (FE) EMIT 
EXTERNAL MEMORY TIMING REGISTER 



D7 De D5 D4 D3 D2 Di Do I 



DATA MEMORY AUTOMATIC WAITS 



00 = NO WAITS 

01 = 1 WAIT 

10 = 2 WAITS 

11 =3 WAITS 

• PROGRAM MEMORY AUTOMATIC WAITS 

00 = NO WAITS 

01 = 1 WAIT 

10 = 2 WAITS 

11 =3 WAITS 



- SLOW MEMORY TIMING 

= DISABLED 

1 = ENABLED 

■ EXTERNAL WAIT INPUT 

= P34 IS NORMAL I/O 

1 = P34 IS EXTERNAL WAIT INPUT 



Still another Super8 feature is an optional exter- 
nal were input using port pin P34. The WAlt input 
function can be used with either or both of the 
above two features. Thus the Data Strobe width 
will have a minimum value determined by the number 
of programmed wait states selected and/or by Slow 
Memory Timing. The WAIT input provides the means 
to stretch it even further. The WAIT input is 
sampled each internal clock time and, if held low, 
can stretch the Data Strobe by adding one internal 
clock period to the Data Strobe time for an 
indefinite period of time. 



Figure 12-9. External Memory Timing Register 



12.8 INSTRUCTION TIMING 

The high throughput of the SuperS is due, in part, 
to the use of instruction pipelining, where the 
instruction fetch and execution cycles are over- 
lapped. During the execution of the current 
instruction, the opcode of the next instruction is 
fetched, as illustrated in Figure 12-10. 
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Figure 12-10. Instruction Pipelining 
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External Interface 



Figures 12-11 through 12-14 show typical instruc- 
tion cycle timing for instructions fetched from 
external memory. All instruction fetch cycles 
have the same machine timing regardless of whether 
the memory is internal or external except when 
external memory timing is extended. In order to 
calculate the execution time of a program, the 



internal clock periods shown in the cycles column 
of the instruction formats in the Instruction Set 
(Chapter 5) should be added. Pipeline cycles are 
transparent to the user and should be ignored. 
Each cycle represents two cycles of the crystal or 
input clock. 
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Figure 12-11. Typical Instruction Cycle Timing (One Byte Instruction) 
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Glossary 



addressing node: The way in which the location of 
an operand is specified. There are seven address- 
ing modes: Register, Indirect Register, Indexed, 
Direct Address, Indirect Address, Relative 
Address, and Immediate. 



auto~echo node: In this UART mode, the data 
coming in on the Receive Data pin is reflected out 
on the Transmit Data pin. The receive section 
still listens to the receive data input; however, 
the data from the transmit section goes nowhere. 

iiase address: The address used, along with an 
index and/or displacement value, to calculate the 
effective address of an operand. The base address 
is located in a general-purpose register, the 
Program Counter, or the instruction. 

baud^rate generator: The UART has its own on-chip 
programmable baud-rate generator that consists of 
two 8-bit Time Constant registers that hold the 
time constant value, a 16-bit Timer /Counter that 
counts down, and a flip-flop at the output 
producing a square wave. 

bi-value aode: A SuperS counter /timer operating 
mode wherein the Time Constant and Capture 
registers alternate in loading the counter. 

byte: A data item containing 8 contiguous bits. 
A byte is the basic data unit for addressing 
memory and peripherals. 

capture: A "capture on external event" feature of 
the Supers that takes a snapshot of the counter 
when a certain event occurs. 



data Henory: A memory address space that can hold 
only data to be read or written, not instruction 
code; data memory is always external to the 
Supers. 

Deskew Counter: A 4-bit counter in each hand- 
shaking channel that is used to count processor 
clocks between the time that valid data is avail- 
able at the port and the handshake signal indi- 
pates that data is available. 

Direct Address (DA) addressing mode: In this 
mode, the effective address is contained in the 
instruction. 



Direct Neaory Access (DMA): An on-chip channel 
that provides high-speed transfers of data direct- 
ly between memory and peripheral devices. 

exception: A condition or event that alters the 
usual flow of instruction processing. The SuperS 
CPU supports two types of exception: reset and 
interrupts. 

extended bus tiaing: The SuperS has the capabil- 
ity of stretching the Data Strobe timing by 1, 2, 
or 3 internal clock periods during external memory 
accesses. The software can set up one timing for 
program memory and a different timing for data 
memory. 

fast interrupt processing: Fast interrupt 
processing completes the interrupt servicing in 6 
clock periods instead of the usual 22. 

Flag register: This register is used to supply 
the status of the SuperS CPU at any time. 

Flag': A dedicated register that saves the 
contents of the Flag register when a fast inter- 
rupt occurs. 

general-purpose registers: The 325 registers that 
can be used as accumulators, address pointers, 
index registers, data registers, or stack regis- 
ters. 

handshaking channels: The SuperS has two identi- 
cal handshaking channels which operate in two 
modes — "fully interlocked" or two-wire mode, and 
"strobed" or single-wire mode. 

lABediate (IN) addressing node: In this mode, the 
operand is contained in the instruction. 

Indexed (X) addressing aode: In this mode, the 
contents of an index register are added to the 
contents of a specified working register or work- 
ing register pair, which holds the index value 
desired. 

Indirect Address (lA) addressing node: In this 
mode, the instruction specifies a pair of memory 
locations and this selected pair, in turn, con- 
tains the actual address of the instruction to be 
executed. 
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Glossary 



Indirect Register (IR) addressing aode: In this 
mode, the contents of the specified register or 
register pair is the address of the operand. 

Instruction Pointer: A 16-bit register that acts 
as Program Counter for a threaded-code language, 
such as Forth, or can be used in the fast inter- 
rupt processing mode for special interrupt 
handling. 

interrupt: An asynchronous exception generated by 
a peripheral device that needs attention. The 
interrupt structure of the SuperS contains 27 dif- 
ferent interrupt sources, 16 vectors, and 8 
levels. 

interrupt level: Interrupt levels provide the top 
level of priority assignment and can be changed by 
programming the Interrupt Priority register. 

Interrupt Priority register (IPR): This register 
assigns 192 different combinations of priority 
when more than one interrupt level is pending. 

interrupt source: An interrupt source is anything 
that generates an interrupt, internal or external 
to the Supers. 

interrupt vector: The vector number is used to 
generate the address of a particular interrupt 
servicing routine. 

local loopback modes In this mode, the data out- 
put from the transmit section of the DART is also 
routed back to the receive section. 

pipelining: Instruction pipelining is a computer 
design technique in which the instruction fetch 
and execution cycles are overlapped. Thus, during 
the execution of the current instruction, the 
opcode of the next instruction is fetched, result- 
ing in high throughput, 

Progran Counter (PC): The 16-bit Program Counter 
controls the sequence of instructions in the 
currently executing program and is not an address- 
able register. 

prograH memory: A memory address space that can 
hold code or data; program memory can be internal 
or external to the SuperS. 

read access: The type of memory access used by 
the CPU for fetching data operands and instruc- 
tions. 



Register (R) addressing mode: In this mode, the 
operand value is the contents of the specified 
register or register pair. 

register file: One of the three types of address 
spaces supported by the SuperS CPU. Register file 
address space is an internal register file compos- 
ed of 325 8-bit wide registers that are logically 
divided into 32 working register groups of eight 
registers each. 

Register Pointer (RP): The two register pointers 
are system registers that contain the base address 
of the two active working register groups of the 
register file. 

Relative Address (RA) addressing mode: In this 
mode, the displacement in the instruction is added 
to the contents of the Program Counter to obtain 
the effective address. 

reset: A CPU operating state or exception that 
results when a reset request is signaled on the 
ftESEY line. A reset initializes the Program 
Status registers. 

Slow Memory timing: An optional feature of the 
Supers in which normal external memory timing is 
slowed by a factor of two. 

Stack Pointer (SP): A 16-bit register pair indi- 
cating the top (lowest address) of the processor 
stack and used by the Call instruction and 
interrupts to hold the return address. 

system registers: System registers govern the 
operation of the CPU and may be accessed using any 
of the instructions that reference the register 
file using the Direct addressing mode. 

Universal Asynchronous Receiver/Transmitter 
(UART): A full duplex asynchronous channel that 
transmits and receives independently with 5 to 8 
bits per character, options for even or odd 
parity, and an optional wake-up feature. 

wake-up feature: A feature of the UART wherein 
pattern match logic detects a pre-specified data 
pattern at the receiver; the pattern can include 
both the received character and a special wake-up 
bit. 

write access: The type of memory access used by 
the CPU for storing data operands. 
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PRELIMINARY INFORMATION 
Product Specification 



June 1987 



Z8®Z8611 MCU 

Military Electrical Specification 



Z8603 Prototyping Device with 2K EPROM Interface 



Features ■ Complete microcomputer, 2K (8601) or 4K 

(8611) bytes of ROM, 128 bytes of RAM, 32 
I/O lines, and up to 62K (8601) or 60K (8611) 
bytes addressable external space each for 
program and data memory. 

- ■ 144-byte register file, including 124 general- 
purpose registers, four I/O port registers, 
and 16 status and control registers. 

■ Average instruction execution time of 1.5 /us, 
maximum of 1 /xs. 

■ Vectored, priority interrupts for I/O, 
counter/timers, and UART. 



Full-duplex UART and two programmable 
8-bit counter/timers, each with a 6-bit 
programmable prescaler. 

Register Pointer so that short, fast instruc- 
tions can access any of nine working register 
groups in 1 /xs. 

On-chip oscillator which accepts crystal or 
external clock drive. 

Single -I- 5 V power supply — all pins TTL 
compatible. 

12.5 MHz. 



General The Z8 microcomputer introduces a new level 

Description of sophistication to single-chip architecture. 
Compared to earlier singl6-chip micro- 
computers, the Z8 offers faster execution; more 
efficient use of memory; more sophisticated 
interrupt, input/output and bit- manipulation 
capabilities; and easier system expansion. 

Under program control, the Z8 can be tailored 
to the needs of its user. It can be configured as a 



stand-alone microcomputer mih 4K bytes 
of internal ROM, a traditional microprocessor 
that manages up to 124K bytes of external 
memory, or a parallel-processing element in a 
system with other processors and peripheral 
controllers linked by the Z-BUS® bus. In all 
configurations, a large number of pins remain 
available for I/O. 
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Pin AS. Address Strobe (output, active Low). 

Description Address Strobe is pulsed once at the begin- 
ning of each machine cycle. Addresses output 
via Port 1 for all external program or data 
memory transfers are valid at the trailing edge 
of AS. Under program control, AS can be 
placed in the high-impedance state along with 
Ports and'l, Data Strobe and Read/Write. 

DS. Data Strobe (output, active Low). Data 
Strobe is activated once for each external 
memory transfer. 

PO0-PO7, PI0-PI7. P2o-P27, P3o-P37. I/O Port 
Lines (input /outputs, TTL-compatible). These 
32 lines are divided into four 8-bit I /O ports 
that can be configured under program control 
f or I / O or external merhory interface . 

RESET. Reset (input, active L ow). RESET ini- 
tiahzes the Z8. When RESET is deactivated. 



program execution beigins from internal 
program location OOOCh- 

ROMless. (input, active LOW). This pin is only 
available on the 44 pin versions of the Z8611. 
When connected to GND disables the 
internal ROM and forces the part to function as a 
Z8681 ROMless Z8. When left unconnected or 
pulled high to Vcc the part will function 
normally as a Z8611. 

R/ W. Read /Write (output). R/ W is Low when 
the Z8 is writing to external program or data 
memory. 

XTALL XTAL2. Crystal I Crystal 2 {iime-hase 
input and output). These pins connect a parallel 
resonant 12.5 MHz crystal or an external single- 
phase 12.5 MHz clock to the on-chip clock 
oscillator and buffer. 



638 



Architecture Z8 architecture is characterized by a flexible 
I/O scheme, an efficient register and address 
space structure and a number of ancillary 
features that are helpful in many applications. 

Microcomputer applications demand power- 
ful I/O capabilities. The Z8 fulfills this with 32 
pins dedicated to input and output. These lines 
are grouped into four ports of eight lines each 
and are configurable under software control to 
provide timing, status signals, serial or parallel 
I/O with or without handshake, and an address/ 
data bus for interfacing external memory. 

Because the multiplexed address/data bus is 
merged with the I/O -oriented ports, the Z8 can 
assume many different memory and I/O con- 
figurations. These configurations range from 
a self-contained microcomputer to a micropro- 
cessor that can address 124K (Z8601) or 120K 
(Z8611) bytes of external memory. 



Three basic address spaces are available to 
support this wide range of configurations: 
program memory (internal and external), data 
memory (external) and the register file (inter- 
nal). The 144-byte random-access register file 
is composed of 124 general-purpose registers, 
four I/O port registers, and 16 control and 
status registers. 

To unburden the program from coping with 
real-time problems such as serial data com- 
munication and counting/timing, an asynchro- 
nous receiver/transmitter (UART) and two 
counter/timers with a large number of userse- 
lectable modes are offered on-chip. Hardware 
support for the UART is minimized because one 
of the on-chip timers supplies the bit rate. 
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Address Program Memory. The 16-bit program counter 

Spaces addresses 64K bytes of program memory space. 

Program memory can be located in two are^s: 
one internal and the other external (F^igure 4). 
The first 4096 (Z8611) bytes consist of on-chip 
mask-programmed ROM. At addresses 
4096 (Z8611) and greater, the Z8 executes 
external program memory fetches. 
* The first 12 bytes of program memory are 
reserved for the interrupt vectors. These loca- 
tions contain six 16-bit vectors that correspond 
to the six available interrupts. 

Data Memory. The Z8 can address 60K (Z8611) 
bytes of external data memory beginning at 
location 4096 (Z8611) (Figure 5). External data 
memory may be included with or separated 



from the external program memory space. 
DM, an optional I/O function that can be 
programmed to appear on pin P34, is used to 
distinguish between data and 
program memory space. 

Register File. The 144-byte register file 
includes four I/O port registers (R0-R3), 124 
general-purpose registers (R4-R127) and 16 
control and status registers (R240-R255). These 
registers are assigned the address locations 
shown in Figure 6. 

Z8 instructions can access registers directly 
or indirectly with an 8-bit address field. The Z8 
also allows short 4-bit register addressing using 
the Register Pointer (one of the control regis- 
ters). In the 4-bit mode, the register file is 
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divided into nine working-register groups, each 
occupying 16 continguous locations (Figure 6). 
The Register Pointer addresses the starting 
location of the active working- register group 
(Figure 7). 

Stacks. Either the internal register file or the 
external data memory can be used for the stack. 



A 16-bit Stack Pointer (R254 and R255) is used for 
the external stack, which can reside anywhere in 
data memory between location^ 2048 (8601) or 
4096 (8611) and 65535. An 8-bit Stack Pointer 
(R255) is used for the internal stack that resides 
within the 124 general-purpose registers 
(R4-R127). 



Serial Port 3 lines P3o and P37 can be programmed as 

Input/ serial I/O lines for full-duplex serial asynchro- 

Output nous receiver/transmitter operation. The bit rate 

is controlled by Counter/Timer 0, at 12 MHz. 

The Z8 automatically adds a start bit and two 
stop bits to transmitted data (Figure 8). Odd 
parity is also available as an option. Eight data 
bits are always transmitted, regardless of parity 

Transmitted Data 

(No Parity) 



selection. If parity is enabled, the eighth bit is 
the odd parity bit. An interrupt request (IRQ4) is 
generated on all transmitted characters. 

Received data must have a start bit, eight data 
bits and at least one stop bit. If parity is on, bit 7 
of the received data is replaced by a parity error 
flag. Received characters generate the IRQ3 
interrupt request. 
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Figure 8. Serial Data Formats 



Counter/ The Z8 contains two 8-bit programmable 

Timers counter/timers (Tq and Ti), 6ach driven by its 

own 6-bit programmable prescaler. The Tj 
prescaler can be driven by internal or external 
clock sources; however, the Tq prescaler is 
driven by the internal clock only. 

The 6-bit prescalers can divide the input fre- 
quency of the clock source by any number from 
1 to 64. Each prescaler drives its counter, which 
decrements the value ( 1 to 256) that has been 
loaded into the counter. When the counter 
reaches the end of count, a timer interrupt 
request — IRQ4 (to) or IRQ5 (Ti) — is generated. 

The counters can be started, stopped, 
restarted to continue, or restarted from the 
initial value. The counters can also be pro- 
grammed to stop upon reaching zero (single- 



pass mode) or to automatically reload the initial 
value and continue counting (modulo-n contin- 
uous mode). The counters, but not the presca- 
lers, can be read any time without disturbing 
their value or count mode. 

The clock source for Ti is user-definable and 
can be the internal microprocessor clock 
divided by four, or an external signal input via 
Port 3. The Timer Mode register configures the 
external timer input as an external clock, a 
trigger input that can be retriggerable or non- 
retriggerable, or as a gate input for the internal 
clock. The counter/timers can be programmably 
cascaded by connecting the Tq output to the 
input of Ti- Port 3 line P36 also serves as a timer 
output (Tout) through which Tq, Tj or the inter- 
nal clock can be output. 
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I/O Ports The Z8 has 32 lines dedicated to input and 

output. These lines are grouped into four ports of 
eight lines each and are configurable as input, 
output or address/data. Under software control, 
the ports can be programmed to provide address 



outputs, timing, status signals, serial I/O, and 
parallel I/O with or without handshake. All ports 
have active pull-ups and pull-downs compatible 
with TTL loads. 



Port 1 can be programmed as a byte I/O port 
or as an address/data port for interfacing 
external memory. When used as an I/O port. Port 
1 may be placed under handshake con- 
trol. In this configuration, Port 3 lines P33 and 
P34 are u sed as the handshake controls RDYi 
and DAVi (Ready and Data Available). 

Memory locations greater than 2048 (Z8601) or 
4096 (Z8611) are referenced through Port 1 . To 
interface external memory. Port 1 must be 
programmed for the multiplexed Address/Data 
mode. If more than 256 external locations are 
required, Port must output the additional 
lines. 

Port 1 can be placed in the high- impedance 
state along with Port 0, AS, DS and R/W, 



allowing the Z8 to share common resources in 
multiprocessor and DMA applications. Data 
transfers can be controlled by assigning P33 as a 
Bus Acknowledge input and P34 as a Bus 
Request output. 
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PortO can be programmed as a nibble I/O 
port, or as an address port for interfacing 
external memory. When used as an I/O port. 
Port may be placed under handshake con- 
trol. In this configuration, Port 3 lines P32 an d 
P35 are used as the handshake controls DAVq 
and RDYq. Handshake signal assignment is 
dictated by the I/O direction of the upper nibble 
PO4-PO7. 

For external memory references. Port can 
provide address bits As-Ai 1 (lower nibble) or 
As-Ais (lower and upper nibble) depending on 
the required address space. If the address range 
requires 12 bits or less, the upper nibble of Port 
can be programmed independently as I/O while 



the lower nibble is used for addressing. When 
Port nibbles are defined as address bits, they 
can be set to the highimpedance state along with 
Port 1 and the control signals AS, DS and R/W. 
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Z8611 
MCU 



^ 



PORTO 

(I/O OR Ag-Ais) 



. HANDSHAKE CONTROLS 
} OAVo AND ROYo 
' (P32 AND P3,) 



Figur* 9b. Port 



Port 2 bits can be programmed independently 
as input or output. The port is always available 
for I/O operations. In addition, Port 2 can be 
configured to provide open-drain outputs. 

Like Ports and 1 , Port 2 may also be 
placed under handshake control. In this con- 
figuration. Port 3 lines P3i a nd P3 6 are used as 
the handshake controls lines DAV2 and RDY2. 
The handshake signal assignment for Port 3 lines 
P3i and P36 ia dictated by the direction (input or 
output) assigned to bit 7 of Port 2. 
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Z8611 


m to 


4 »r 


MCU 








^::z) 



HANDSHAKE CONTROLS 
SAVi AND ROY2 
(P3, AND P3,) 



Figuro 9c. Port 2 



Port 3 lines can be configured as I/O or 
control lines. In either case, the direction of the 
eight lines is fixed as four input (P3o-P33) and 
four output (P34-P37). For serial I/O, lines P3o 
and P37 are programmed as serial in and serial 
out respectively. 

Port 3 can also provide the following con- 
t rol fu nctions: handshake for Ports 0, 1 and 2 
(DAVand RDY); four external interrupt 
request signals (IRQ0-IRQ3); timer input and 
output signals ( Tin Q nd Tqut) ^^id Data 
Memory Select (DM). 









* 




* 




* 


Z8611 


* 


* 


MCU 




* 







Figxire 9d. Port 3 
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Interrupts The Z8 allows six different interrupts from 

eight sources: the four Port 3 lines PSq-PSs, 
Serial In,- Serial Out, and the two counter/timers. 
These interrupts are both maskable and 
prioritized. The Interrupt Mask register globally 
or individually enables or disables the six inter- 
rupt requests. When more than one interrupt is 
pending, priorities are resolved by a pro- 
grammable priority encoder that is controlled by 
the Interrupt Priority register. 

All Z8 interrupts are vectored. When an inter- 
rupt request is granted, an interrupt machine 



cycle is entered. This disables all subsequent 
interrupts, saves the Program Counter and status 
flags, and branches to the program memory 
vector location reserved for that interrupt. This 
memory location and the next byte contain the 
16-bit address of the interrupt service routine for 
that particular interrupt request. 

Polled interrupt systems are also supported. To 
accommodate a polled structure, any or all of the 
interrupt inputs can be masked and the Interrupt 
Request register polled to determine which of the 
interrupt requests needs service. 



Clock The on-chip oscillator has a high-gain, 

parallel-resonant amplifier for connection to a 
crystal or to any suitable external clock source 
(XTALl = Input, XTAL2 = Output). 

The crystal source is connected across XTALl 
and XTAL2, using the recommended capacitors 



(Ci < 15 pF) from each pin to ground. The 
specifications for the crystal are as follows: 

■ AT cut, parallel resonant 

■ Fundamental type, 12.5 MHz maximum 

■ Series resistance, Re ^ 100 Q 
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Instruction Addressing Modes. The following notation is used 

Set to describe the addressing modes and instruction 

Notation operations as shown in the instruction summary. 

IRR Indirect register pair or indirect working -register 

pair address 

Irr Indirect working-register pair only 

X Indexed address 

• DA Direct address 

RA Relative address 

IM Immediate 

R Register or working-register address 

r Working-register address only 

IR Indirect-register or indirect working- register 

address 

Ir Indirect working -register address only 

RR Register pair or working register pair address 

Symbols. The following symbols are used in 

describing the instruction set. 

dst Destination location or contents 

src Source location or contents 

cc Condition code (see list) 

@ Indirect address prefix 

SP Stack pointer (control registers 254-255) 

PC Program counter 

FLAGS Flag register (control register 252) 

RP Register pointer (control register 253) 

IMR Interrupt mask register (control register 251) 



Assignment of a value is indicated by the symbol 
"— ". For example, 

dst — dst + src 
indicates that the source data is added to the 
destination data and the result is stored in the 
destination location. The notation "addr(n)" is used 
to refer to bit "n" of a given location. For example, 

dst (7) 
refers to bit 7 of the destination operand. 

Flags. Control Register R252 contains the following 
six flags: 



C 
Z 

s 

V 
D 
H 



Carry flag 
Zero flag 
Sign flag 
Overflow flag 
Decimal-adjust flag 
Half -carry flag 



' Affected flags are indicated by: 

Cleared to zero 

1 Set to one 

* Set or cleared according to operation 

— Unaffected 

X Undefined 
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Condition 


Valu* 


Mnemonic 


Meaning 




Flags S«t 




Codes 


. 1000 




Always true 










0111 


c 


Carry 




C = 1 






nil 


NC 


No carry 




C = 






OHO 


Z 


Zero 




Z = 1 






1110 


NZ 


Not zero 




Z = 






1101 


PL 


Plus 




S =0 






0101 


MI 


Minus 




S = 1 






0100 


OV 


Overflow 




V = 1 






1100 


NOV 


No overflow 




V = 






Olio 


-EQ 


Equal 




Z = 1 






1110 


NE 


Not equal 




Z = 






1001 


GE 


Greater than or equal 




(S XOR V) = 






0001 


LT 


Less than 




(S XOR V) = 1 






1010 


GT 


Greater than 




(Z OR (S XOR V)] = 






0010 


LE 


Less than or equal 




IZ OR (S XOR V)] « 1 






nil 


UGE 


Unsigned greater than 


or equal 


C =0 






0111 


ULT 


Unsigned less than 




C = 1 






1011 


UGT 


Unsigned greater than 




(C = AND Z = 0) * 1 






0011 


ULE 


Unsigned less than or equal 


(C OR Z) = 1 






0000 




Never true 






^ 


Instruction 


















1 
( 


OPC 1 


CCF. 01, El, IRET, NOP. 
RCF. RET, SCF 

INCr 






Formats 








dst 1 OPC 1 





One-Byte Instructions 



OPC 1 MODE 








CLR, CPL. DA, DEC, 


dst/src 


OR [T 


1 1 


dst/src 


PUSH, RL, RLC, RR, 
RRG, SRA, SWAP 




OPC 


JP, CALL (IndirMt) 


d(t 


ORti. 

OR \r 


1 1 
1,1 0| 


dst 
src 








OPC 


SRP 


VALUE 








OPC 


MODE 


ADC, ADO, AND, 


d,. 


src 


CP, OR, SBC, SUB, 
TCM, TM, XOR 




MODE 


OPC 


LO, LDE, LDEI, 


dst/src 


src/dst 


LDC, LOCI 






dst/src 1 OPC 


LO 


src/dst 








dst 1 OPC 


LO 


VALUE 








dst/CC 1 OPC 


OJNZ. JR 


RA 





OPC I Mobi" 



OPC I MooT 



MODE I OPC 



DAu 



OR 


1110 


src 


OR 


1110 


dst 



ADC, AOO, AND, CP. 
LO, OR, SBC. SUB. 
TCM, TM, XOR 



ADC, AOO, AND. CP. 
LO, OR, SBC. SU~ 
TCM, TM. XOR 



OR 


1110 


src 


OR 


1110 


dst 



MODE 


OPC 


dst/src 


X 


ADDRESS 



Two-Byte InstnictiooB 



Three-Byte Instructioas 



Figure 12. Instruction Formots 
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Instruction 
Summory 



Instruction Addr Mod< Opcod« HagsAlisct^d 

and Operation j_, _„ ^* ^ - « « .^ « 
dst irc (H«x) C Z S V D H 



Ape dst,src 
dst — dst + src -h 


(Note 1) 
C 


ID 


♦ * * * * 


ADD dst,src 
dst ^ dst + src 


(Not^ 1) 


OD 


* * * * * 


AND d8t,8rc (Note 1) 
dst - dst AND src 


5D 


- ♦ ♦ - - 


CAU dst 

SP - SP - 2 
@SP - PC; PC - 


DA 
IRR 
-dst 


D6 
D4 




CCF 

C - NOT C 




EF 


* _ ^ — _ — 


CLR dst 

dst - 


R 
IR 


BO 
Bl 




COM dst 

dst - NOT dst 


R 
IR 


60 
61 


- ♦ * - - 


CP dst,src 
dst - src 


(Note 1) 


AD 


****.. 


DA dst 

dst - DA dst 


R 
IR 


40 
41 


... X - - 


DEC dst 

dst - dst - 1 


R 
IR 


00 
01 


-***-- 


DECW dst 

dst - dst - 1 


RR 
IR 


80 
81 


-...-- 


DI 

IMR (7) - 




8F 





DJNZ r.dst 
r- r-l 

lit ^ 

PC - PC + dst 
Range: +127, -128 



RA 



EI 

IMR (7) - 1 



rA 
r = 0-F 

9F 



INC dst 

dst *- dst + 1 



R 

IR 



rE 

r = 0-F 

20 

21 



INCW dst 

dst - dst + 1 



RR 

IR 



AO 
Al 



* * * — ■ 



IHET 

FLAGS -@SP; SP-SP+ 1 
PC - @ SP; SP - SP + 2; IMR (7) 



I? ccdst 
if cc is true 
PC - dst 



DA 
IRR 



IR cc,dst 
if cc is true, 

PC - PC + dst 
Range: +127,-128 



RA 



LD dst, src 
dst — src 



Ir 
R 
R 
R 
IR 
IR 



Im 
R 



R 
IR 
Im 
Im 
R 



BF 
«-l 

cD 

c = 0-F 

30 

cB 
c = 0-F 

rC 
r8 
r9 
r = 0-F 
C7 
D7 
E3 
F3 
E4 
E5 
E6 
E7 
F5 



LDC, dst,src 

dst '— src 



Irr 



Irr 



02 
D2 



LDCI dst, src Ir Irr . 03 

dst - src Irr Ir D3 

r — r + 1; rr — rr + 1 



Instruction Addr Modo 
ond Oporotion ^ ^^ 



LDE dst, src 
dst — src 



Irr 



Irr 



LDQ dst, src Ir Irr 

dst — src Irr Ir 

r — r+1; rr*-rr+l 



NOP 



OR dst, src 
dst -dst OR src 



(Note 1) 



POP dst 

dst - @SP 
SP - SP + 



R 

IR 



PUSH src R 

SP-SP-1; ®SP-src IR 



RCF 

C-0 



RET 

PC-@SP; SP-SP + 2 



Opcodo Flags Alfoctod 

Byto — !i- — 

(Hox) C Z S V D H 

82 

92 

83 

93 

FF 

40 ^ * ♦ - - 

50 

51 

70 

71 

CF 

AF 



RLdst .ji^R 



IR 



90 
91 



RLC dst 



fi^S^fn 



10 

11 



HH dst cgx^] R 



IR 



EO 
El 



«»^^^*C5:^]« 



IR 



CO 
01 



SBC dst,src 
dst «- dst - src - 



(Note 1) 



3D 



* 1 



SCF 

0- 1 



DF 



SRA dst La^g^J R 



IR 



DO 
Dl 



- - 



SRP src 

RP - src 



Im 



31 



SUB dst, src 
dst — dst - src 



(Note 1) 



2D 



* * * * I 



SWAP dst 



'IR 



FO 
Fl 



X * * X - - 



TCM dst, src (Note 1) 

(NOT dst) AND src 



6D 



- * * - 



TM dst, src 
dst AND src 



(Note 1) 



7D 



XOR dst, src 
dst- dst XOR src 



(Note 1) 



BD 



> * * 



Not«l 

These instructions have an identical set of addressing 
modes, which are encoded for brevity. The first opcode 
nibble is found in the instruction set table above. The 
second nibble is expressed symbolically by a D in this 
table, and its value is found in the following table to the 
right of the applicable addressing mode pair. 

For example, to determine the opcode of a ADC 
instruction use the addressing modes r (destination) and 
Ir (source). The result is 13. 



Addr Mod* 



dst 


src 


r 


r 


r 


Ir 


R 


R 


R 


IR 


R 


IM 


IR. 


IM 



Lowor 
Opcod« Nibblo 



m 
m 
a 

m 
m 
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Registers 



R240 SIO 
Serial I/O Register 

(FOh; Read/Write) 



R244T0 
Counter/Timer Register 

(F4h; Read/Write) 



|D,|D,|Dg|D«|D3|Da|D,|Dci 



|Dr|D,|Ds|04|D3|P2|Oi 



S 



- SERIAL DATA (Dq « LSB) 



T, INITI* 
-(RANGE: 



T4 CURRENT VALUE (WHEN READ> 



R241TMR 
Timer Mode Register 

(FIh; Read/Write) 



R245 PREO 
Prescoler Register 

(F5h; Write Only) 



Tout MODES 
T USED » 00 
To OUT ■ 01 ' 



NOT 

oOUT 
T, OUT - lu 
INTERNAL CLOCK OUT 3 11 

Tin modes 
EXTERNAL CLOCK INPUT a 00 
GATE INPUT « 01 
TRIGGER INPUT a 10 - 
(NONRETRIGGERABLE) 

TRIGGER INPUT - 11 
(RETRIGGERABLE) 



d«|d3|D;|d, |d7| 



^:: 



NO FUNCTION 
LOAD To 

DISABLE To COUNT 
ENABLE Tg COUNT 



M 



COUNT MODE 
- - To SINGLE-PASS 
1 = To MOOULO-N 



R242 Tl 
Counter Timer 1 Register 

{F2h; Read/Write) 



R246 P2M 
Port 2 Mode Register 

(F6h; Write Only) 



|d,|d.|d5|d«|d3|d^|d,[do| 



T, CURRENT VALUE (WHEN READ) 



|d,|d,|Ds|d4|d3|d2|d,|Do| 



P2o-P27 VO DEFINITION 
- DEFINES BIT AS OUTPUT 
1 DEFINES BIT AS INPUT 



R243 PREl 
Presccder 1 Register 

(F3h; Write Only) 



R247 P3M 
Port 3 Mode Register 

(F7h; Write Only) 




l count mode 
» t, single-pass 
1 = t, modulo-n 

clock source 

1 = t, internal 

t, external timing input 
(t,n) mode 



|D,|D,[Ds|D4|D3|Da|D,|Do| ' 



P33 = INPUT P34 = OUTPUT 

-?J}P33 = INPUT P34 = DH 

11 P33 = SSVi/RDYl P34 = ROYI/OAVI 



Figure 13. Control Registers 
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Registers 

(Continued) 



R248 POIM 
Port and 1 Mode Registe 

(F8h; Write Only) 



R252 FLAGS 
Flag Register 

(FCh; Read/Write) 



PO4-PO7 MODE 
OUTPUT = 00 
INPUT = 01 
A,2-Ai5 = IX 

EXTERNAL MEMORY TIMING 
NORMAL = 
EXTENDED = 



|d,|d,|c 


sJD* D 


alo^foJ'Ool 



PO0-PO3 MODE 

00 »= OUTPUT 

01 = INPUT 
IX s A,-Ai, 

STACK SELECTION 

=> EXTERNAL 

1 = INTERNAL 

P1o-P1r MODE 

00 = BYTE OUTPUT 

01 = BYTE INPUT 

10 = AD0-AD7 

11 « HLGHiMPEDANCE AD0-AO7, 

AS, DS, R/W, Aa-Aii, Ai2-Ai5 
IF SELECTED 



|D,|D,|Ds|D«|D3|0a|D, JDol 



L^ 



USER FLAG F1 

USER FLAG F2 
-HALF CARRY FLAG 
-DECIMAL ADJUST FLAG 
-OVERFLOW FLAG 



-ZERO FLAG 
-CARRY FLAG 



R249 IPR 
Interrupt Priority Register 

(F9h; Write Only) 



R253RP 
Register Pointer 

(FDh; Read/Write) 



1 0, 1 Ds 1 D 


5 i D, i D3 1 Dj jJ), i Do 1 












RESERVED • 

IRQ3, IRQ5 PRIORITY (GROUP A) 










INTERRUPT GROUP PRIORITY 
RESERVED = 000 
C > A > B = 001 


REGISTER 


= IROS > IRQ3 ■"■ 

1 = IRQ3 > IRQS 

IRQO, IRQ2 PRIORITY (GROUP B) 








A > C > B = Oil 
B > C > A = 100 
C > B > A = 101 
B > A > C = 110 
RESERVED =111 


POINTER 


1 = IRQO > IRQ2 
IRQI, IRQ4 PRIORITY (GROUP C) 







I Or I D, j D; j D4 j Da I D; j D, j Dp I 



l=i 



R250IRQ 
Interrupt Request Register 

(FAh; Read/Write) 



R254 SPH 
Stack Pointer 

(FEh; Read/Write) 



|D7|,Og|D5|D,|D3|Da[D, JDoT 

,=r — n 



{D;|'Dg|D5|D«|D3|D2|D, JDqJ 



- IRQO = P32 INPUT (Do - IRQO) 
IRQI = P33 INPUT 
IRQS > P3i INPUT 
IRQS « P3o INPUT, SERIAL INPUT 
IRQ4 * To, SERIAL OUTPUT 
IRQS s Ti 



STACK POINTER UPPER 
" BYTE (SPa-SPis) 



R251 IMR 
Interrupt Mask Register 

(FBh; Read/Write) 



R255 SPL 
Stack Pointer 

(FFh; Read/Write) 



I D, I Dg I b; I D« I D3 I D; I D, I Dp I 



O7 I 0, Ds D4 D} 



io»iOi|Oo| 



STACK POINTER LOWER 
BYTE <SPo-SP7> 



-1 ENABLES INTERRUPTS 



Figtire 13. Control Registers (Continued) 
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Opcode 
Map 



Low*r Nibbl* (H«x) 
6 7 8 



8 

X 



I 



6,5 

DEC 

Ri 


6,5 
DEC 

IRi 


6,5 

ADD 

ri,ra 


6,5 

ADD 

ri, Ira 


10,5 

ADD 

R2,Ri 


10,5 

ADD 

IRa,Ri 


10,5 

ADD 

Ri,IM 


10,5 

ADD 

IRi,IM 


6,5 
LD 
ri,Ra 


6,5 

LD 

ra,Ri 


12/10,5 
DJNZ 
ri,RA 


12/10,0 

JR 

cc,RA 


6,5 

ID 

ri.IM 


12/10,0 

IP 
cc,DA 


6,5 , 
INC 

ri 




6.5 

RLC 

Hi 


6,5 

RLC 

IRi 


6,5 

ADC 

ri,ra 


6,5 

ADC 

ri,Ira 


10,5 

ADC 

Ra,Ri 


10,5 
ADC 

IRa,Ri 


10,5 

ADC 

Ri,IM 


10,5 

ADC 

IRi,IM 


1 


r 


• \ 


' 


\ 


1 


' 


f 


i 


' 


\ 


f 




< 




6,5 

INC 

Ri 


6,5 
INC 
IRi 


6,5 

SUB 

ri, ra 


6,5 
SUB 

ri,Ir2 


10,5 
SUB 
Ra,Ri 


10,5 
SUB 
IRa.Ri 


10,5 
SUB 

Ri,IM 


10, 5 ^ 
SUB 

IRi,IM 




IRRi 


6,1 
SRP 

IM 


6,5 
SBC 

Tl,T2 


6,5 

SBC 

ri,Ir2 


10,5 
SBC 
Ra,Ri 


10,5 
SBC 

IRa,Ri 


10,5 

SBC 

Ri,IM 


10,5 

SBC 

IRi,IM 




8,5 
DA 
Ri 


8,5 
DA 

IRi 


6,5 
OR 

ri,ra 


6,5 
OR 

ri,Ira 


10,5 

OR 

Ra,Ri 


10,5 

OR 

IRa,Ri 


10,5 
OR 

Ri,IM 


10,5 
OR 

IRi,IM 




10,5 
POP 
Ri 


10,5 
POP 
IRi 


6,5 
AND 

ri,ra 


6,5 
AND 

ri,Ira 


10,5 
AND 
R2,Ri 


10,5 
AND 
IRa.Ri 


10,5 
AND 
Ri.IM 


10,5 
AND 
IRi,IM 




6,5 

COM 

Ri 


6,5 
COM 


6,5 
TCM 

ri,ra 


6,5 
TCM 

ri,Ir2 


10,5 
TCM 
R2,Ri 


10,5 
TCM 
IRa.Ri 


10,5 
TCM 
Ri,IM 


10,5 
TCM 
IRi,IM 




10/12, 1 

PUSH 

Ra 


12/14, 1 
PUSH 

IR2 


6,5 
TM 

ri, ra 


6,5 
TM 

ri,Ira 


10,5 

TM 

Ra,Ri 


10,5 

TM 

IR2,Ri 


10,5 
TM 

Ri,IM 


10,5 
TM 

IRi,IM 




10,5 

DECW 

RRi 


10,5 
DECW 

IRi 


12,0 
LDE 
ri,Irra 


18,0 
LDEI 

Iri,Irr2 










6,1 
DI 


6,5 
RL 
Ri 


6,5 
RL 
IRi 


12,0 
LDE 
Irri 


18,0 
LDQ 

Ira,Irri 










6,1 
EI 


10,5 

INCW 

RRi 


10,5 

INCW 

IRi 


6,5 
CP 

ri,ra 


6,5 
CP 

ri,Ira 


10,5 

CP 

Ra.Hi 


10,5 

CP 

IRa,Ri 


10,5 

CP 

Hi,IM 


10,5 

CP 

IRi,IM 


14,0 
RET 


6,5 
CLR 
Ri 


6,5 
CLR 

IRi 


6,5 

XOR 

ri,ra 


6,5 
XOR 

ri,Ir2 


10,5 
XOR 
Ra,Ri 


10,5 
XOR 
IRa.Ri 


10,5 
XOR 
Ri,IM 


10,5 
XOR 

IRi,IM 


16,0 
IRET 


6,5 
RRC 
Ri 


6,5 
RRC 

IRi 


12,0 
LDC 

ri, Irra 


18,0 
LDQ 

In, Irra 








10,5 

LD 

ri, X. Ra 


6,5 
RCF 


6,5 
SRA 
Ri 


6,5 
SRA 

IRi 


12,0 
LDC 

ra.Irri 


18,0 
LDQ 

Ira., Irri 


20,0 

CALL* 

IRRi 




20,0 
CALL 

DA 


10,5 

LD 

ra, X, Ri 


6,5 
SCF 


6,5 
RR 
Ri 


6,5 
RR 

IRi 




6,5 

LD 

ri, Ira 


10,5 

LD 

R3,Ri 


10,5 

LD 

IRa,Ri 


10,5 

LD 

Ri,IM 


10,5 

LD 

IRi,IM 


6,5 
CCF 


8,5 
SWAP 

Ri 


8,5 
SWAP 

IRi 




6,5 

LD 

Iri, ra 




10,5 

LD 

R2.IR1 






6,0 
NOP 



Bytes p«r 
Instruction 



.Low«r 
Opcode 
Nibble 



Upper 
Opcode 
Nibble 



Execution f Pipeline 

Cycles V 4 y Cycles 

V— ^ 



Mnemonic 




Legend: 

R » 8-Bit Address 
r = 4-Bit Address 
Hi or ri = Dst Address 
Ra or ra = Src Address 

Sequence: 

Opcode, First Operand, Second Opserand 

Note: The blank areas are not defined. 



*2-byte instruction; fetch cycle appears as a 3-byte instruction 



649 



Absolute Voltages on all pins 

Maximum with respect to GND -0.3 V to +7.0 V 

Ratings Operating Ambient 

Temperature See Ordering Information 

Storage Temperature .^-65°Cto 4-150°C 

Standard The DC characteristics listed below apply for 

Test the following standard test conditions, unless ' 

Conditions otherwise noted. All voltages are referenced to 

GND. Positive current flows into the reference 

pin. 

Standard conditions are: 

D +4.75 V < Vcc 2S +5.25 V 

D GND = V 

D 0°C ^ T^ :S +70°C 



Stresses greater than those listed under Absolute Maxi- 
mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 



FROM OUTPUT . 
UNDER TEST * 



ISOpF^: ^J-^ 




Figure 14. Test Load 1 



DC 

Character- 
istics 



Symbol Paramet«r 


Min 


Max 


Unit 


Condition 


VCH 


Clock Input High Voltage 


3.8 


Vcc 


V 


Driven by External Clock Generator 


VCL 


Clock Input Low Voltage 


-0.3 


0.8 


V 


Driven by External Clock Generator 


VlH 


Input High Voltage 


2.0 


Vcc 


V 




ViL 


Input Low Voltage 


-0.3 


0.8 


V 




Vrh 


Reset Input High Voltage 


3.8 


Vcc 


V 




Vrl 


Reset Input Low Voltage 


-0.3 


0.8 


V 




VOH 


Output High Voltage 


2.4 




V 


Ioh = -250mA 


Vol 


Output Low Voltage 




0.4 


V 


loL =+ 2.0 mA 


IlL 


Input Leakage 


-10 


10 , 


mA 


OV:S ViN :S+ 5.25 V 


loL 


Output Leakage 


-10 


10 


mA 


OV^ ViN :S +5.25 V 


Im 


Reset Input Current 




-50 


HA 


Vcc = +5.25 V, Vrl = 0V 


Ice 


Vcc Supply Current 




150 


mA 
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AC Characteristics 



External I/O 
or Memory 
Read and 
Write Timing 



Ji 



♦<«>*► 



PORT 0, 

m 



X 



iz>: 



-*<}>*■ 



Mt^* 



KH 



OS 

(READ) 



3^ 



-^dy 



K 



-<!>- 



-<D- 



ZDC 



X 



6i 

(WRITE) 



K^ 



-0- 



>' 



Kz: 



) <: 






*<a)-^ 



K 



y 



Figure 15. External I/O or Memory Read/Write 



No. Symbol 



Parameter 



Min Max 



Notes*t' 



1 TdA(AS) 

2 TdAS(A) 

3 TdAS(DR) 

4 TwAS 

5 TclAz(DS) 

6 — TwDSR 

7 TwDSW 

8 TdDSR(DR) 

9 ThDR(DS) 

10 . TdDS(A) 

11 TdDS(AS) 

12 — TdR/W(AS)~ 

13 TdDS(R/W) 

14 TdDW(DSW) 

15 TdDS(DW) 

16 TdA(DR) 

17 TdAS(DS) 



Address Valid to AS t Delay 
AS t to Address Float Delay 
M T to Read Data Required Valid 
AS Low Width 
Address Float to DSi 

- DE (Read) Low Width 

DS (Write) Low Width 

DS i to Read Data Required Valid 
Read Data to DS T Hold Time 
DS t to Address Active Delay 
DSrtoASiDelay 

- R/W Valid to AS t Delay [ 

U5t to R/W Not Valid 

Write Data Valid to DS (Write) 4 Delay 
nS T to Write Data Not Valid Delay 
Address Valid to Read Data Required Valid 
M T to DS ; Delay 



35 
45 

55 

■185- 
110 


45 
55 
-30- 
35 
35 
45 

55 



220 



130 



255 



2,3 
2,3 
1,2,3 
1,2,3 

■1,2,3 
1,2,3 
1,2,3 

2,3 
2.3 
-2,3 
2,3 
2,3 
2,3 
1,2,3 
2,3 



NOTES: 

1 . When using extended memory timing add 2 TpC. 

2. Timing numbers given are for minimum TpC. 

3. See clock cycle time dependent characteristics table. 



t Test Load 1 . 

° All timing references use 2.0 V for a logic "1" and 0.8 V for a logic "0". 

* All units in nanoseconds (ns). 



651 



AC Characteristics 



Additional 

Timing 

Table 



-0- 



^-^"W^iCTw^^ 




Figure 16. Additionol Timing 



No. Symbol 



Parameter 



Min 



Max 



Notes* 



1 


TpC 


2 


TrCTfC 


3 


TwC 


4 


TwTinL 


5- 


. , TiiiTii lTT 




6 


TpTin 


7 


TrTinJfTin 


8a 


TwIL 


8b 


TwIL 


9 


TwIH 



Input Clock Period 

Clock Input Rise And Fall Times 

Input Clock Width 

Time Input Low Width 

Timer Input High Width 

Timer Input Period 
Timer Input Rise And Fall Times 
Interrupt Request Input Low Time 
Interrupt Request Input Low Time 
Interrupt Request Input High Time 



80 


1000 


1 




15 


1 


26 




1 


70 

oT. .r' 




2 








8TpC 




2 




100 


2 


70 




2,3 


3TpC 




2,4 


STpC 




2,3 



NOTES: 

1 . Clock timing references 
a logic "0". 

2. Timing reference uses 2, 
a logic "0". 



uses 3.8 V for a logic "1" and 0.8 V for 
V for a logic "1" and 0.8 V for 



3. Interrupt request via Port 3 (P3i-P33). 

4. Interrupt request via Port 3 (P3q). 
* Units in nanoseconds (ns). 



Memory Port 
Timing 



^ 



<}>- 



ADDRESS VALID 



X 



DATA IN VALID 








Figure 17. Memory Port Timing 








No. 


Symbol 


Parameter 


Min 


Max 


Notes* 


1 
2 


TdA(DI) 
ThDI(A) 


Address Valid to Data Input Delay 
Data In Hold time 


, 


320 


1,2 
1 



NOTES: 

1. Test Load 2. 

2. This is a Clock-Cycle-Dependent parameter. For clock frequencies 
other than the maximum, use the following formula: 5 TpC - 95 



* Units are nanoseconds unless otherwise spjecified. 
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Handshake 
Timing 



5E 



DATA IN VALID 



\ 



-KD- 



0^ 






\ 



-<i>- 



Jr 



Figure 18a. Input Handshake 



DATA OUT VALID 



OAV 

(OUTPUT) 



V 



-®- 



/ 



N: 



<D 



-<I>- 



r 



Figure 18b. Output Handshoke 



No. Symbol 



Parameter 



Min 



Max 



Notes* 



1 TsDI(DAV) 

2 ThDI(DAV) 

3 TwDAV 

4 TdDAVIf(RDY) 

5 — TdDAVOf(RDY)- 

6 TdDAVIr(RDY) 

7 TdDAVOr(RDY) 

8 TdDO(DAV) 

9 TdRDY(DAV) 



Data In Setup Time 
Data In Hold time 
Data Available Width 
DA^i Input to RDYi Delay 
- DM i Output to RD Y i Delay - 
D^r Input to RDYt Delay 
DAV T Output to RDY t Delay 
Data Out to DAV i Delay 
Rdyi Input to DMT Delay . 




160 
120 





30 





120 



120 



140 



1,2 

-1.3 

1,2 

1,3 

1 

1 



NOTES: 

1. Test load 1 

2. Input handshake 

3. Output handshake 

T All timing references use 2.0 V for a logic "1" and 0.8 V for 
a logic "0". 



* Units in nanoseconds (ns). 



Clock- 
Cycle-Time- Number Symbol 
Dependent 
Characteristics 



Equation 



1 TdA(AS) 

2 TdAS(A) 

3 TdAS(DR) 

4 TwAS 

5 TwDSR 

7 TwDSW 

8 TdDSR(DR) 
Td(DS)A 
TdDS(AS) 

-TdR/W(AS)- 
TdDS(R/W) 



10 

11 

12- 

13 

14 

15 

16 

17 



TdDW(DSW) 
TdDS(DW) 
TdA(DR) 
TdAS(DS) 



TpC-50 

TpC-40 

4TpC-110* 

TpC-30 

- 3TpC-65* - 
2TpC-55* 

3TpC-120* 
TpC-40 
TpC-30 

— TpC-55 — 
TpC-50 
TpC-50 
TpC-40 

5TpC-160* 
TpC-30 



* Add 2TpC when using extended memory timing. 



653 



MIL-STD-883 MILITARY PROCESSED PRODUCT 



Mil-Std-883 establishes uniform methods and proce- 
dures for testing microelectronic devices to insure the 
electrical, mechanical, and environmental integrity and 
reliability that is required for military applications. 

Mil-Std-883 Class B is the industry standard product 
assurance level for military ground and aircraft 
application. 



The total reliability of a system depends upon tests that 
are designed to stress specific quality and reliability 
concerns that affect microelectronic products. 

The following tables detail the i 00% screening and elec- 
trical tests, sample electrical tests, and Qualification/ 
Quality Conformance testing required. 



ZIlog Military Product Fiow 











OPTICAL 


WAFER 




SCRIBE AND 




INSPECTION 


FABRICATION 




BREAK 




(MIL.STD-883 
Method 2010) 



PRE-SEAL 

VISUAL 

(MILSTO-883 

Method 2010) 



SEAL AND 
LOT 1.0. 



ENVIRONMENTAL SCREENING 

■ STABILIZATION BAKE 

■ TEMPERATURE CYCLE 

■ CENTRIFUGE 




ELECTRICAL 
TESTS 



BURN-IN 
(MIL-STD-883 
Method 1015) 



FINAL 

ELECTRICAL 

TESTS 

3 TEMPS 



FINE LEAK 
GROSS LEAK 



GROUP A 

SAMPLE 

ELECTRICAL 



QUALITY 

CONFORMANCE 

INSPECTION 

(QCI) 




FINAL 

ELECTRICAL 

TESTS 



OA 

SAMPLE 

ELECTRICAL 



EXTERNAL 
VISUAL 



EXTERNAL 

VISUAL 

(MIL-STD-883 

Method 2009) 




CMS 

LMB 

. PARTS 
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Table I 

MIL-STD-883 Class B Screening Requirements 
l\/lethod 5004 



Test 


IVIii-Std-883 
IVIethod 


Test Condition 


Requirement 


Internal Visual 


2010 


Condition B 


100% 


Stabilization Bake 


1008 


Condition C 


100% 


Tennperature Cycle 


1010 


Condition C 


100% 


Constant Acceleration (Centrifuge) 


2001 


Condition E or D^Note 1), Yi Axis Only 


100% 


Initial Electrical Tests 




. Zilog Military Electrical Specification 
Static/DC Tc = +25°C 


100% 


Burn-In 


1015 


Condition D(Note2)^ -|60 hours. 
Ta= +125°C 


100% 


Interim Electrical Tests 




Zilog Military Electrical Specification 
Static/DC Tc= +25X 


1000/0 


PDA Calculation 




PDA = 5% 


100% 


Final Electrical Tests 




Zilog Military Electrical Specification 
Static/DC Tc = +125°C. -55°C 
Functional, Switching/ACTc = +25°C 


100% 


Fine Leak 
Gross Leak 


1014 
1014 


Condition A2 
Condition C 


100% 
100% 



Quality Conformance Inspection (OCI) 

Group A Each Inspection^ Lot 5005 (See Table II) 

Group B Every Week 5005 (See Table III) 

Group C Periodically (Note 3) 5005 (See Table IV) 

Group D Periodically (Note 3) 5005 (See Table V) 



Sample 
Sample 
Sample 
Sample 



External Visual 



2009 



100% 



QA— Ship 



100% 



NOTES: 

1 . Applies to larger packages which have an inner seal or cavity perimeter of two inches or more in total length or have a package 
mass of >5 grams. 

2. In process of fully implementing of Condition D Burn-In Circuits. Contact factory for copy of specific burn-in circuit available. 

3. Performed periodically as required by Mil-Std-883, paragraph 1 .2.1 b(1 7). 
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Table II Group A 

Sample Electrical Tests 
MIL-STD-883 Method 5005 



Subgroup 


Tests 


Temperature (Tc) 


LTPD 
Max Accept = 2 


Subgroup 1 


Static/DC 


+ 25°C 


2 


Subgroup 2 


Static/DC 


+ 125°C 


3 


Subgroups 


Static/DC 


-55°C 


5 


Subgroup? 


Functional 


+ 25«C 


2 


Subgroup 8 


Functional 


-55°Cand+125X 


5 


Subgroup 9 


Switching/AC 


+ 25X 


2 


Subgroup 10 


Switching/AC 


+125°C 


3 


Subgroup 11 


Switching/AC 


~55°C 


5 



NOTES: 

• The specKic parameters to be included for tests in each subgroup shall be as specified in the applicable detail electrical specification. Where no 
parameters have been identified in a particular subgroup or test within a subgroup, no Group A testing is required for that subgroup or test. 

• A single sample may be used for all subgroup testing. Where required size exceeds the lot size, 100% inspection shall be allowed. 

• Group A testing by subgroup or within subgroups may be performed in any sequence unless otherwise specified. 
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Table III Group B 

Sample Test Performed Every Week to 

Test Construction and Insure Integrity of Assembly Process. 

MiL-STD-883 Method 5005 



Subgroup 


Mil-Std-883 
Method 


Test Condition 


Quantity or 
LTPD/Max Accept 


Subgroup 1 

Physical Dimensions 


2016 




2/0 


Subgroup 2 

Resistance to Solvents 


2015 




4/0 


Subgroup 3 

Solderability 


2003 


Solder Temperature 
■i-245°C±5°C 


15(Notel) 


Subgroup 4 

Internal Visual and Mechanical 


2014 




1/0 


Subgroup 5 

Bond Strength 


2011 


C 


15(Note2) 


Subgroup 6(Note 3) 

Internal Water Vapor Content 


1018 


1000 ppm. 
maximum at +100°C 


3/0 or 5/1 



Subgroup 7(Note 4) 

Seal 
7a) Fine Leak 
7b) Gross Leak 



1014 



7a) ^2 
7b) C 



Subgroup 8<Note 5) 

Electrostatic Discharge Sensitivity 



3015 Zilog Military Electrical 

Specification 
Static/DC Tc= +25°C 
A = 20-2000V 
B = >2000V 

Zilog Military Electrical 

Specification 
Static/DC Tc = +25°e 



15/0 



NOTES: 

1 . Number of leads inspected selected from a minimum of 3 devices. 

2. Number of bond pullaselected from a minimum of 4 devices. 

3. Test applicable only if the package contains a dessicant. 

4. Test not required if either 1 00% or sample seal test is performed between final electrical tests and external visual during Class B screening. 

5. Test required for initial qualification and product redesign. 
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Table IV Group C 

Sample Test Performed Periodically to Verify Integrity of the Die. 
MIL-StD-883 Method 5005 



Subgroup 



Mii-Std-883 
Method 



Test Condition 



Quantity or 
LTPD/Max Accept 



Subgroup 1 

Steady State Operating Life 

End Point Electrical Tests 



1 005 Condition D(Note 1)^ -| qqq hours at 

+ 125°C 

Zilog Military Electrical Specification 
Tc = +25°C, +125°C, -55°C ' 



Subgroup 2 

Temperature Cycle 


1010 


Condition C 


Constant Acceleration (Centrifuge) 


2001 


Condition E or D(Note 2)^ Yi Axis Only 


Seal 


1014 




2a) Fine Leak 
2b) Gross Leak , 




2a) Condition A2 
2b) Condition C 


Visual Examination 


1010or1011 





End Point Electrical Tests 



Zilog Military Electrical Specification 
Tc= +25°C. +125°C, -55°C 



15 



NOTE; 

1 . In process of fully implementing Condition D Burn-In Cii'cuits. Contact factory for copy of specific burn-in circuit available. 

2. Applies to larger packages which have an inner seal or cavity perimeter of two inches or more in total length or have a package 
mass of >5 grams. 
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Table V Group D 

Sample Test Performed Periodically to Insure Integrity of the Package. 
MIL-STD.883 Method 5005 


Subgroup 


Mil-Std-883 
Method 


Test Condition 


Quantity or 
LTPD/Max Accept 


Subgroup 1 

Physical Dimensions 


2016 




.15 


Subgroup 2 

Lead integrity 


2004 


Condition B2 or D(Notei) 


15 



Subgroup 3 

Thermal Shock 


1011 


Condition B minimum, 
1 5 cycles minimum 


Temperature Cycling 


1010 


Condition C, 1 00 cycles minimum 


Moisture Resistance 


1004 




Seal 


1014 




3a) Fine Leak 
3b) Gross Leak 




3a) Condition A2 
3b) Condition C 


Visual Examination 


1004 or 1010 




End Point Electrical Tests 




Zilog Military Electrical Specification 
Tc= +25°C, +125°C. -55°C 


Subgroup 4 

Mechanical Shock 


2002 


Condition B minimum 


Vibration Variable Frequency 


2007 


Condition A minimum 


Constant Acceleration (Centrifuge) 


2001 


Condition E or D(Note2)^ Yi Axis Only 


Seal 


1014 




4a) Fine Leak 
4b) Gross Leak 




4a) Condition A2 
4b) Condition C 


Visual Examination 


lOIOorlOII 





15 



End Point Electrical Tests 



Zilog Military Electrical Specification 
Tc = +25°C. +125°C, -55°C 



15 



Subgroup 5 

Salt Atmosphere 

Seal 
5a) Fine Leak 
5b) Gross Leak 



1009 
1014 



Condition A minimum 

5a) Condition A2 
5b) Condition C 



NOTES: 

1 . Lead Integrity Condition D for leadless chip carriers. 

2. Applies to larger packages which have an inner seal or cavity 
perimeter of two inches or more in total length or have a package 
mass of >5 grams. 



3. Not applicable to leadless chip carriers. 

4. LTPD based on number of leads. 

5. Not applicable for solder seal packages. 



15 



Visual Examination 


1009 






Subgroup 6 

Internal Water Vapor Content 


1018 


5,000 ppm. maximum water 
content at +100°C 


3/0 or 5/1 


Subgroup 7(Note 3) 

Adhesion of Lead Finish 


2025 




15(Note4) 


Subgroup 8(Note 5) 

Lid Torque 


2024 




5/0 
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Product Specification 



Z8®Z8681 Military 
RONless Microcomputer 



June 1987 



FEATURES 

■ Complete microcomputer, 24 I/O lines, and up to 64K 
bytes of addressable external space each for program 
and data memory. 

■ 143-byte register file, including 124 general-purpose 
registers, three I/O port registers, and 16 status and 
control registers. 

■ Vectored, priority interrupts for I/O, counter/timers, and 
UART. 

■ On-chip oscillator that accepts crystal or external clock 
drive. 



Full-duplex UART and two programmable 8-bit 
counter/timers, each with a 6-bit programmable 
prescaler 

Register Pointer so that short, fast instructions can 
access any one of the nine working-register groups. 

Single + 5V power supply— all I/O pins TTL-compatible. 

Available in 8 MHz. 



GENERAL DESCRIPTION 

The Z8681 is the ROMIess version of the Z8 single-chip 
microcomputer. The Z8681 offers all the outstanding 
features of the,Z8 family architecture except an on-chip 
program ROM. Use of external memory rather than a 
preprogrammed ROM enables this Z8 microcomputer to be 
used in low volume applications or where code flexibility is 
required. 

The Z8681 can provide up to 1 6 output address lir>es, thus 
permitting an address space of up to 64K bytes of data or 
program memory Eight address outputs (ADq-ADj) are 
provided by a multiplexed, 8-bit, Address/Data bus. The 
remaining 8 bits can be provided by the software 
configuration of Port to output address bits A8-A15. 



Available address space can be doubled (up to 1 28K bytes) 
by programming bit 4 of Port 3 (P34) to act as a data memory 
select output (DM). The two states of DM together with the 
16 address outputs can define separate jdata and memory 
address spaces of up to 64Kbytes each. 

There are 143 bytes of RAM located on-chip and organized 
as a register file of 1 24 general-purpose registers, 1 6 control 
and status registers, and three I/O port registers. This 
register file can be divided into nine groups of 16 working 
registers each. Configuring the register file in this manner 
allows the use of short format instruction?; in addition, any of 
the individual registers can be accessed directly. 
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ABSOLUTE MAXIMUM RATINGS 

Guararvteed by characterization/design 

Voltages on all pins except RESET 

with respecttoGND : . . .-0.3V to +7.0V 

Operating Case Tennperature - 55°C to + 1 25°C 

Storage Temperature Range -65°Cto +150°C 

Absolute MaxinnunrT Power Dissipation 1 .7 W 

STANDARD TEST CONDITIONS 

The DC characteristics listed below apply for the following 
standard test conditions, unless otherwise noted. All 
voltages are referenced to GND (OV). Positive current flows 
into the referenced pin. 

Military Operating Temperature Range (Tq) 
-55°Cto+125°C 

Standard Military Test Condition 
+ 4.5 < Vcc <+ 5.5V 



Stresses greater than those listed under Absolute Maximum Ratings may 
cause permanent damage to the device. This is a stress rating only; 
operation of the device at any condition above those indicated in the 
operational sections of these specifications is not implied. Exposure to 
absolute maximum' rating conditions for extended periods may affect 
device reliability. 



+5V 



FROM OUTPUT , 
UNDER TEST ^ 



150 pfS; 



Test Load 




DC CHARACTERISTICS 



Symbol 


Parameter 


Min 


Max 


Unit 


Condition 


VCH 


Clock Input High Voltage 


3.8a 


Vcc^ 


V 


Driven by External Clock Generator 


VCL 


Clock Input Low Voltage 


-0.3b 


0.8a 


V 


, Driven by External Clock Generator 


V|H 


Input High Voltage 


2.0a 


Vcc^ 


V 




V|L 


Input Low Voltage 


-0.3b 


0.8a 


V 




Vrh 


Reset Input High Voltage 


3.8a 


Vcc^ 


V 




VRL 


Reset Input Low Voltage 


-0.3b 


0.8a 


V 




VOH 


Output High Voltage 


2.4a 




V 


l0H= -250mA 


Vol 


Output Low Voltage 




0.4a 


V 


Iql = +2.0nnA 


l|L 


Input Leakage 


-10a . 


10a 


hA 


V|N - OV 5.5V 


lOL 


Output Leakage 


-10a 


10a 


mA 


V|N =' OV 5.5V 


l|R 


Reset Input Current 




-50a 


mA 


Vcc = MAX, Vrl = OV 


Ice 


Vcc Supply Current 




230a 


mA 


All outputs and I/O pins floating 



CAPACITANCE 



Symbol 



Parameter 



Max 



Unit 



Cmax 



Maximum Capacitance 



15c 



pt 



Ta = 25<>C, f = 1 MHz. 
Parameter Test Status: 

a Tested 

b Guaranteed 

" Guaranteed by Characterization/Design 
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3( 



*<!2>^ 



PORT 0, 
DM 



>: 



X 



Y*^S)^ 



~\^' 



DS 

(READ) 



DS 

(WRITE) 



X 



'^-®^ 



^ 



1-A7 \ 



<D- 






-0- 



^ D0-D7 I 



-(>>- 



A0-A7 



X 



D0-D7 OUT 



X 



-<iy 



y 



X 



} <: 






-<!5>^ 



-y 



Figure 1 . External I/O or Memory Read/Write Timing 



AC CHARACTERISTICS 

External I/O or Memory Read and Write Timing 









Z8681 


' 










8 MHz 




Number 


Symbol 


Parameter 


Min 


Max 


Notes* » 


1 


TdA(AS) 


Address Valid to AS t Delay 


50a 




2.3 


2 


TdAS(A) 


AS t to Address Float Delay 


70a 




2,3 


3 


TdAS(DR) 


AS t to Read Data Required Valid 




420a 


1.2,3 


4 


TwAS 


AS Low Width 


80a 




2,3 


5 


TdAz(DS) 


Address Float to DS^ 


Qb 






6 


TwDSR 


DS (Read) Low Width 


250a 




1,2,3 


7 


TwDSW 


DS (Write) Low Width 


160a 




1,2.3 


8 


TdDSR(DR) 


DS i to Read Data Required Valid 




200a 


1,2,3 


9 


ThDR(DS) 


Read Data to DS t Hold Time 


Oa 






10 


TdDS(A) 


D^ t to Address /\ctive Delay 


70a 




2,3 


11 


TdDS(AS) 


Us t to AS ^ Delay 


70a 




2,3 


12 


TdR/W(AS) 


R/W Valid to A§t Delay 


50a 




2,3 


13 


TdDS(R/W) 


DSt to R/W Not Valid 


60a 




2.3 


14 


TdDW(DSW) 


Write Data Valid to DS (Write) I Delay 


50a 




2.3 


15 


TdDS(DW) 


D§ t to Write Data Not Valid Delay 


60a 




2.3 


16 


TdA(DR) 


Address Valid to Read Data Required Valid 




41 Oa 


1,2.3 


17 


TdAS(DS) 


^ t to DSI Delay 


80a 




2,3 


NOTES: 

1 . When using extended memory timing add 2 TpC. Parameter Test Status: 

Timing numbers given are for minimum TpC. a Tested 
J. See clock cycle time dependent characteristics table. b Guaranteed 








* All units in nanoseconds (ns). "^ Guaranteed by Characterization/Design 
° All timing references use 2.0V for a logic " 1 " and 0.8V for a logic "0". 
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-<iy 



-<3>^ 



JTkd -4-kd k-<3>~4 



Tin 



IRQn 




k-<8>^] ^ © ^ 



Figure 2. Additional Timing 



AC CHARACTERISTICS 

Additional Timing Table 



Number Symbol 



Parameter 



Z8681 

8 MHz 

Min Max 



Notes* 



1 TpC 

2 TrC.TfC 

4 TwTinL 

5 TwTinH 



Input Clock Period 

Clock Input Rise and Fall Times 

Input Clock W'dth 

Timer Input Low Width 

Timer Input High Width 



NOTES: 

1 . Clock timing references use 3.8V for a logic " 1 " and 0.8V for a logic "0". 

2. Timing references use 2.0V for a logic "1" and 0.8V for a logic "0". 

3. Interrupt request via Port 3. 

Parameter Test Status: 

a Tested 

b Guaranteed 

c Guaranteed by Characterization/Design 



125a 

37b 

100b 

3TpCb 



1000a 
25b 



4. Interrupt request via Port 3 (P3i-P33) 

5. Interrupt request via Port 3 (P3o) 
* Units in nanoseconds (ns). 



6 


TpTin 


Timer Input Period 


8TpCb 




2 


7 


TrTin.TfTin 


Timer Input Rise and Fall Times 




100b 


2 


8A 


TwIL 


Interrupt Request Input Low Time 


100b 




2,3,4 


8B 


TwIL 


Interrupt Request Input Low Time 


STpCb 




2,3,5 


9 


TwIH 


Interrupt Request Input High Time 


STpCb 




2,3 
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DAV 

(INPUT) 



DATA IN VALID 



(i>J 



'Hr 



(I> 



-<I>- 
-<I>- 



\ 



sT 



-<D- 



Jr 



Figure 3a. Input Handshake Timing 



DAV 

(OUTPUT) 



RDY 

(INPUT) 





U-— <j) — M 



\ 



DATA OUT VALID 



-®- 



/ 



tz: 



<D 



-0- 



r 



Figure 3b. Output Handshalce Timing 



AC CHARACTERISTICS 

Handshake Timing 



Z8681 



Number Symbol 



Parameter 



Min 



Max 



Notest* 



1 


TsDI(DAV) 


Data In Setup Time 


Oa 


2 


ThDI(DAV) 


Data In Hold Tinne 


230a 


3 


TwDAV 


Data Available Width 


175a 


4 


TdDAVIf(RDY) 


DAVI Input to RDY 4 Delay 




5 


TdDAVOf(RDY) 


DAV i Output to RDY 1 Delay 


Oa 


6 


TdDAVIr(RDY) 


DAV t Input to RDY t Delay 




7 


TdDAVOr(RDY) 


Da7 t Output to RDY t Delay 


Oa 


8 


TdDO(DAV) 


Data Out to DAV i Delay 


50a 


9 


TdRDY(DAV) 


Rdyi Input to DA7t Delay 


Ob 



175a 



175a 



200a 



NOTES: 

1 . Input handshake 

2. Output handshake 

t All timing references use 2.0V for a logic " 1 " and 0.8V for a logic "0". 
* Units in nanoseconds (ns). 

Parameter Test Status: 

a Tested 

b Guaranteed 

c Guaranteed by Characterization/Design 
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PIN DESCRIPTION 

AS. Address Strobe (output, active Low). Address Strobe is 
pulsed once at the beginning of each n^iachine cycle. 
Addresses output via Port 1 for all external program or data 
memory transfers are valid at the trailing edge of AS. 

DS. Data Strobe (output, active Low). Data Strobe is 
activated once for each external memory transfer. 

PO0-PO7, P2o-P27, P3o-P37. I/O Fortunes (input/outputs, 
TTL-compatible). These 24 lines are divided into three 8-bit 
I/O ports that can be configured under program control for 
I/O or external memory interface. 

PI0-PI7. Address/Data Port (bidirectional). Multiplexed 
address (A0-A7) and data (D0-D7) lines used to interface with 
program and data memory. 



RESET. Reset (input, active Low). RESET initializes the 
Z8681 . After R ESET th e Z8681 is in the extended memory 
mode. When RESET is deactivated, program execu- 
tion begins from program location OOOCh- 

R/W. /?ead/Wr/te (output). R/W is Low when the Z8681 is 
writing to external program or data memory 

XTAL1, XTAL2. Crystal 1, Crystal 2 (time-base input and 
output). These pins connect a parallel-resonant crystal to the 
on-chip clock oscillator and buffer 



PACKAGE PINOUTS 



TIMING 




AND 
CONTROL 










PORTO 




PROGRAMMABLE) 

I/O OR Af,-A,6 






** 














PORT1 




(BYTE 
PROGRAMMABLE) 




ADr,-AD/ 













RESET 

R/W 

DS 

AS 

POo 

PO1 

PO2 



PO4 



+ 5V 

GNO 

XTAL1 

XTAL2 

P2o 

P2i 

P22 

P23 

P24 



Z8681 
MCU 



P2s 
P26 

P27 

P3o 
P3i 
P32 

P33 
P34 
P35 
P36 
P37 



PORT 2 

(BIT PRO- 
GRAMMABLE) 

I/O 



PORTS 

SERIAL AND 
PARALLEL I-/0 
AND CONTROL 



+ 5V [^ 


1 


W 


40\ 


DP3. 


XTAL2 C 


2 




39 


3p3. 


XTAL1 C 


3 




36 


3p2, 


P3.C 


4 




37 


1'^ 


P30C 


5 




36 


J '2, 


RESET l^ 


6 




35 


]P2. 


R/W C 


7 




34 


3pj3 


DSC 


8 




33 


DP2. 


A-SC 


9 




32 


3P2, 


P3si: 


10 


Z8681 


31 


]P2, 


GND [^ 


11 


MCU 


30 


DP33 


ohL 


12 




29 


JP3. 


po,L 


13 




28 


J Oh 


PO.C 


14 




27 


2 OH 


po^c 


15 




26 


3p's 


P03 c 


16 




25 


lou 


po,[: 


17 




24 


lou 


PO,C 


18 




23 


lou 


PO.C 


19 




22 


3p'- 


PO-C 


20 




21 


?"' 



Figure 4. Pin Functions 



Figure 5. 40-pin Duai-in-Line Package (DIP), 
Pin Assignments 
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MIL-STD-883 MILITARY PROCESSED PRODUCT 



Mil-Std-883 establishes uniform methods and proce- 
dures for testing microelectronic devices to insure the 
electrical, mechanical, and environmental integrity and 
reliability that is required for military applications. 

Mil-Std-883 Class B is the industry standard product 
assurance level for military ground and aircraft 
application. 



The total reliability of a system depends upon tests that 
are designed to stress specific quality and reliability 
concerns that affect microelectr9nic products. 

The following tables detail the 1 00% screening and elec- 
trical tests, sample electrical tests, and Qualification/ 
Quality Conformance testing required. 



ZIlog Military Product Piow 











OPTICAL 


WAFER 




SCRIBE AND 




INSPECTION 


FABRICATION 




BREAK 




(MIL-STD-883 
Method 2010) 



PRE-SEAL 






VISUAL 




SEAL AND 


(MIL-STD-883 


* 


LOT I.D. 


Method 2010) 







ENVIRONMENTAL SCREENING 

■ STABILIZATION BAKE 

■ TEMPERATURE CYCLE 

■ CENTRIFUGE 





BURN-IN 
(MIL-STD-883 
Method 1015) 






FINAL 

ELECTRICAL 

TESTS 

3 TEMPS 




1 


FINE LEAK 
GROSS LEAK 






GROUP A 

SAMPLE 

ELECTRICAL 




^ 


QUALITY 

CONFORMANCE 

INSPECTION 

(QCI) 



FINE LEAK 
GROSS LEAK 



QA 

SAMPLE 

ELECTRICAL 



EXTERNAL 

VISUAL 

(MIL-STD-883 

Method 2009) 



EXTERNAL 
VISUAL 




CMB 

LMB 

, PARTS , 
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Table I 

MIL-STD-883 Class B Screening Requirements 
Method 5004 



Test , 


Mil-Std-883 
Method 


Test Condition 


Requirement 


Internal Visual 


2010 


Condition B 


1000/0 


Stabilization Bake 


1008 


Condition C 


1000/0 


Tennperature Cycle 


1010 


Condition C 


1000/0 


Constant Acceleration (Centrifuge) 


2001 


Condition E or D^^Pte 1), Yi Axis Only 


1000/0 


Initial Electrical Tests 




Zilog Military Electrical Specification 
Static/DC Tc= +25X 


1000/0 


Burn-In 


1015 


Condition D(Note 2) 160 hours, 
Ta= +125°C 


lOOo/o 


Interim Electrical Tests 




Zilog Military Electrical Specification 
Static/DC Tc = +25°C 


lOOO/o 


PDA Calculation 




PDA = 5% 


lOOo/o 


Final Electrical Tests 




Zildg Military Electrical Specification 
Static/DC Tc = +125X, -55X 
Functional, Switching/AC Tc = +25°C 


lOOO/o 


hine Leai< 
Gross Leak 


1U14 
1014 


Condition B 
Condition C 


1000/0 
lOOo/o 



Quality Conformance Inspection (QCI) 

Group A Each Inspection Lot 5005 (See Table II) 

Group B Every Week 5005 (See Table III) 

Group C Periodically (Note 3) 5005 (See Table IV) 

Group D Periodically (Note 3) 5005 (See Table V) 



Sample 
Sample 
Sample 
Sample 



External Visual 



2009 



1000/0 



QA— Ship 



1000/0 



NOTES: 

1 . Applies to larger packages which have an inner seal or cavity perimeter of two inches or more in total length or have a package 
mass of >5 grams. 

2. In process of fully implementing of Condition D Burn-In Circuits. Contact factory for copy of specific burn-in circuit available. 

3. Performed periodically as required by Mil-Std-883, paragraph 1 .2.1 b(1 7). 
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Table II Group A 

Sample Electrical Tests 
MIL-STD-883 Method 5005 



Subgroup 


Tests 


Temperature (Tc) 


LTPD 
Max Accept = 2 


Subgroup 1 


Static/DC 


+ 25°C 


2 


Subgroup 2 


Static/DC 


+ 125°C 


3 


Subgroup 3 


Static/DC 


-55°C 


5 


Subgroup 7 


Functional 


+ 25°C 


2 


Subgroup 8 


Functional 


-55°Cand+125°C 


5 


Subgroup 9 


Switching/AC 


+ 25°C 


2 


Subgroup 10 


Switching/AC 


+ 125°C 


3 


Subgroup 1 1 


Switching/AC 


-55°C 


5 



NOTES: 

• The specific parameters to be included for tests in each subgroup shall be as specified in the applicable detail electrical specification. Where no 
parameters have been identified in a particular subgroup or test within a subgroup, no Group A testing is required for that subgroup or test. 

• A single sample may be used for all subgroup testing. Where required size exceeds the lot size, 1 00% inspection shall be allowed. 

• Group A testing by subgroup or within subgroups may be performed in any sequence unless otherwise specified. 
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Table III Group B 

Sample Test Performed Every Week to 

Test Construction and Insure Integrity 6f Assembly Process. 

MIL-STD-883 Method 5005 



Subgroup 


Mil-Std-883 
Method 


Test Condition 


Quantity or 
LTPD/Max Accept 


Subgroup 1 

Physical Dimensions 


2016 




2/0 


Subgroup 2 

l^dsistance to Solvents 


2015 




4/0 


Subgroup 3 

Solderability 


2003 


Solder Temperature 
+ 245X±5°C 


15(Note1) 


Subgroup 4 

Internal Visual and Mechanical 


2014 




1/0 


Subgroup 5 

Bond Strength 


2011 


C 


15(Note2) 


Subgroup 6(^ote 3) 

Intei-nal Water Vapor Content 


1018 


1000 ppm. 
maximum at +100X 


3/0 or 5/1 



Subgroup 7(Note 4) 

Seal 
7a) FiheLeak 
7b) Gross Leak 



1014 



7a) B 
7b) C 



Subgroup 8(Note 5) 

Electrostatic Discharge Sensitivity 



301 5 Zilog Military Electrical 

Specification 

Static/DC Tc= +25°C 

A = 20-2000V 

B = >2000V 
Zilog Military Electrical 
Specification 

Static/DC Tc= +25°C 



15/0 



NOTES: 

1. Number of leads inspected selected from a minimum of 3 devices. 

2. Number of bond pulls selected from a minimum of 4 devices. 

3. Test applicable only if the package contains a dessicant. 

4. Test not required if e|her i 00% or sample seal test is performed between final electrical tests and external visual during Class B screening. 

5. Test required for initial qualification and product redesign. 
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Table fV Group C 

Sample Test Performed Periodically to Verify Integrity of the Die. 
MIL-STD-883 i\^ethod 5005 



Subgroup 



Mii-Std-883 
Method 



Test Condition 



Quantity or 
LTPD/l\Max Accept 



Subgroup 1 

Steady State Operating Life 

End Point Electrical Tests 



1 005 Condition D^^ote 1)^ i qOO hours at 

+ 125X 

Zilog Military Electrical Specification 
Tc = +25°C. +125°C. -55°C " 



Subgroup 2 

Tennperature Cycle 


1010 


Condition C 


Constant Acceleration (Centrifuge) 


2001 


Condition E or D(Note 2\ y^ Axis Only 


Seal 
2a) Fine Leak 
2b) Gross Leak 


1014 


2a) Condition B 
2b) Condition C 


Visual Examination 


1010or1011 




End Point Electrical Tests 




Zilog Military Electrical Specification 



15 



NOTE: 

1 . la process of fully implementing Condition D Burn-In Circuits. Contact factory for copy of specific burn-in circuit available. 

2. Applies to larger packages which have an inner seal or cavity perimeter of two inches or more in total length or have a package 
mass of >5 grams. 
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Table V Group D 

Sample Test Performed Periodically to Injure Integrity of the Package. 
MIL-STD-883 Method 5005 



Subgroup 


Mil-Std-883 
Method 


Test Condition 


Quantity or 
LTPD/Max Accept 


Subgroup 1 

Physical Dimensions 


2016 




15 


Subgroup 2 , 

Lead Integrity 


2004 


Condition B2 or D(Notei) 


15 



Subgroup 3 

Thermal Shock 



Temperature Cycling 

Moisture Resistance 

Seal 
3a) Fine Leak 
3b) Gross Leak 

Visual Examination 

End Point Electrical Tests 



1011 


Condition B minimum, 
15 cycles minimum 


1010 


Condition C, 100 cycles minimum 


, 1004 




1014 


3a) Condition B 
3b) Condition C 


1004 or 1010 





Zilog Military Electrical Specification 
Tc= +25°C. -f125°C, -55°C 



15 



Subgroup 4 

Mechanical Shock 

Vibration Variable Frequency 

Constant Acceleration (Centrifuge) 

Seal 
4a) Fine Leak 
4b) Gross Leak 

Visual Examination 

End Point Electrical Tests 



2002 


Condition B minimum 


2007 


Condition A minimum 


2001 


Condition E or D(Note2)^ Yi Axis Only 


1014 


4a) Condition B 
4b) Condition C 


lOIOorlOII 





Zilog Military Electrical Specification 
Tc= +25°C, +125°C, -55°C 



15 



Subgroup 5 

Salt Atmosphere 

Seal 
5a) Fine Leak 
5b) Gross Leak 



1009 
1014 



Condition A minimum 

5a) Condition B 
5b) Condition C 



NOTES: 

1 . Lead Integrity Condition D for leadless chip carriers. 

2. Applies to larger packages which have an inner seal or cavity 
perimeter of two inches or more in total length or have a package 
mass of >5 grams. 



3. Not applicable to leadless chip carriers. 

4. LTPD based on number of leads. 

5. Not applicable for solder seal packages. 



15 



Visual Examination 


1009 






Subgroup 6 

Internal Water Vapor Content 


1018 


5,000 ppm. maximum water 
content at +100°C 


3/0 or 5/1 


Subgroup 7(Note 3) 

Adhesion of Lead Finish 


2025 




15(Note4) 


Subgroup 8(Note 5) 

Lid Torque 


2024 




5/0 
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PACKAGE INFORMATION 




I. 0.300_J 

r-REF^ 




0.045 
±.005 



18-Pin Ceramic Paclcage 



NOTE: 

0.031 RADIUS - 

NOTCH ALT. 



Jn 



0.100 
0.025 
0.030 



-«- U.U4U 1 



, 0.325 I 

h— ♦.025— H 
-.015 



0.920_ 
"MAX 



-S HK-"'^ 



&« '^WmM 



0-* h- r-Hh~ O-iOO' 
5 • o.oia 11 TYP 



0.018 ' 
0X103 



m~1~l0.02( 
IFmin 




18«Pin Plastic Paclcage 

NOTE: Package dimensions are given in inches. To convert to nnillimeters, multiply by 25.4 
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PACKAGE INFORMATION (Continued) 



ioo«nncATioN~ 






_o.Mo ^ o.m ojm 



I Sh 



4?H 






MIN I "^ 
0.0« 

era 




L^ J Lug JLj 

■OTHENDS 

M-PlB CMOBiie Podmg* 




I 0.010 H •■ 1 



I, 0.00 J 0.121 

*.0» ^ MIN 



^ 



0.0M 




L aioonAx J L-O-w -JL.*'-52 

n-PlB Cwdip Poekog* 




TVTVvvvv^vvyvT 



H Sim " • 

I- — :^ — 4 ^ 




1^ 



? 



0.100 0A10 0.1 




f-r 



NOTE: PaeUg* dtoMntiom ai« gi««n In tndm. To convart to miUUiwton, multiply br 25.4. 
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PACKAGING INFORMATION 



l^^f^^/^A^r^A^A^f^A/^Af^A/^AAA 




"VVVVVVVVVVVVVVVVVVVT 

1 '20 



-6100- 



^ 



2.070 
MAX 


1. 0.0S0 
*~TYP 


0.180 
MAX 






1 .4" 


K^J 


mmmmwj^ 

L 0.110 11 0.021 ^ , 0.060 

1^0.090 ^r 0.015 ^ r— 0.040 0.125 



40-pin Plastic DIP 



0.565 

MAX 

GLASS 



r^r^r^r^r^r^r^r^r^r^f^r^r^r^r^rlr^r^r^^ 




ijijijijijijijijijijijijijijijijijijij'^ 
1 20 



0.010 
±.002- 

TYP 



0.056 

-SEALING GLASS ±.O03 

TYP 



'^r 




L_ 0.100 MAX 
■^BOTH ENDS 



I I 0.100 
— ^ k-*.OlO 



^\^i 



0.040 
±.020 



4d-pin Cardip Package 



NOTE: Package dimensions are given in inches. To convert to nnillinneters, nnultiply by 25.4. 
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PACKAGE INFORMATION (Continued) 



0.300 t 
0.200 



IDENTIFICATION 



e-ooooooooooo 



P 



ooooooooooo 



-0.100 X 11 = 1.100- 



-0.100 X 19 = 1.900- 
2.311 



CERAMIC LID-x 



[IT 



0.107 
\ MAX 



PIN STAND-OFF 



— W^ 

4 PL U 



0.200 
0.300 -• 



r 



♦- 0.300 -► 
-0.400 



> 0175 * ^ II, 


' °-^^^ 0.064 1 1 \ 


f A \7ff\/''\/''\/' '\/''\/-'\/''\/'-'\/''\/'-'\/''\/'' '■' ■' ' ' ' '■' '■ ' 


T n 0.070 


LOW 0.200REFT 11 1 11 ♦„ .,„ ♦ 
PROFILE \^ «-130 ^ 
SOCKET UUU. UUUUUUUUUUUUUUUUT 



40-pm Low Profile Protopack 
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45» X 0.045 MAX-v 



^0.050 PIN1 

TYPICAL A IDENTIFICATION 



45«x 0.45 MAX 




45- xO.OIOMAX-^ 
3 PLACES 



VIEW TOWARD PC BOARD 



* DIMENSION FROM CENTER TO CENTER OF RADII 



44-pin PCX; 



0.010 

-±.002 

TYP 



_0.590_ 
REF 




IDENTIFICATION 
SOCKET A-/ 



40-pin Protopack 
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PACKAGING INFORMATION (Continued) 



AAAAAAAf^AAAAAA/SA/^AAAAAAA 



0.560 
0.540 



0.062_ 
RADIUS 



d 



■WWVWWWWWWVWWW" 



2.470 
~MAX~ 



4 PLACES 
0.018/0.015 RAD. TYP. 




48-Pin Duai-in-Line Package (DIP), 
Plastic 



0.300 t 
0.200 



PIN 1 1DENTIFICATION'-' 
SOCKET A IDENTIRCATlONi-' 



— @- ©@©©©©®©@@@@© 



©@©®©©@©©©©©© 



-0.100x13s1.300- 



-0.100 X 23 s 2.300 
^2.470 





PIN STAND-OFF _J L_ 0.018 DIA 

4 PL —Hw-^ 



0.155 
0.109 



TiTiTrnTrrni 1 1 1 1 1 1 1 1 1 

_JL_ 0.018 
^r TYR 



0.071 i 



L-O.OJ 



48-Pin tow Profile 
Protopack (T) 



NOTE: Package dimensions are given in inches. To convert to millimeters, multiply by 25.4. 
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PACKAGE INFORMATION (Continued) 



(.0314^.004) 
Mi A 



(.oi4t.ooe) 

0.351.05 



-mEmm 



- 23 



34 



cm 



n 



44 



O 



22 



(.394 4 .012) 
10X0.3 



lElMl 



A 



11 



(.304 ± .012) 
10 ± .3 

(.551 ±.01 2) 
" 14 + .3 



(.551 1 .012) 
14 + .3 



(.00216.010) 
.5 to .25 



(.0391.004) 

1±.1 



t t 

(0.006) 

.15 
NonKnat 



L/^^^^^^p^^rull^'" 



(.039 1 .006) 



44-Pin Quad Flat Pack (QFP) 



NOTE: OFP package dimonsions are in 
Unite with are In inches. 
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ORDERING INFORMATION 



Z8 MCU, 2K ROM, 8 MHz 
28-pin DIP 

20860008PSCRXX 
Z0860008PECRXX 



Z8MCU 
40-pin DIP 



44-pin FCC 
2KROM 



40-pin Protopak 
2KXROM 



Z0860112PSCRXXX Z0860112VSCRXXX Z0860312TSF 

Z0860112DSERXXX 

Z0860112PECRXXX 

Z0860112DEERXXX 



4KROM 



4KXROM 



Z0861112PSCRXXX Z0861112VSCRXXX Z0861312TSF 

Z0861112PECRXXX 

Z0861112DSERXXX 

Z8 MCU with BASIC/Debug Interpreter, 8 MHz 
40-pin DIP 

Z0867108PSCR002 
Z0867108PECR002 

Z8681 ROMIess MCU 

40-pin DIP 44-pin PCC 



8 MHz 

Z0868108PSC 

Z0868108DSE 

Z0868108PEC 

Z0868108DEE 

12 MHz 

Z0868112PEC 
Z0868112PSC 
Z0868112DSE 
Z0868112DEE 

16 MHz 
Z0868116PSC 



Z0868108VSC 



Z0868112VSC 
Z0868112VEC 



Z0868116VSC 



Low Cost ROMIess MCU, 8 MHz 

Z0868208PSC 

Z0868408PSC 



Low Power ROMIess MCU, 8 MHz 
40-pin DIP 44-prn PCC 



Z0869108PSC 



Z0869108VSO 



Z8 ROMIess MCU, 12 MHz 
40-pin DIP 44-pin PCC 



Z0869112PSC 
Z0869112PEC 



Z0869112VSC 



Z8 ROMIess MCU, 16 MHz 
40-pin DIP 44-pin PCC 



Z8 MCU, 4K ROM, 
12 MHz 
40-pin DIP 



Z8 MCU, 4K ROM, 
16 MHz 
40-pin DIP 



Z86C1 1 1 2PECRXXX Z86C1 1 1 6PSCRXXX 
44-pin PLCC 44-pin PLCC 

Z86C1112VECRXXX Z86C1116VSCRXXX 



Z8 MCU, 8K ROM 
40-pin DIP 

Z36C2112PECRXXX 
Z86C2116PSCRXXX 
Z86C2112CEARXXX 



Z8 MCU, 8K PROM 

40-pin DIP 44-pin PLCC 



Z86E2112PEC 
Z86E2116PSC 
Z86E2112CEA 

44-pin PLCC 

Z86F2112VEC 
Z86E2116VSC 



Z86C2112VECRXXX 
Z86C2116VSCRXXX 



Z86C27/Z86C97 DTC 
64-Pin DIP 

Z86C2708PSCRXXX 
Z86O2708PSCRXXX 
Z86O9708PSCR314 



Z8 ROMIess MCU 

40-pin DIP 44-pin PCC 



Z86C9112PEC 
Z86C9116PSC 



Z86C9112VEC 
Z86C9t16VSC 



Z8 4KROMMCU,12MHz 

Z0861112CMBRXXX 



ZS ROMIess MCU, 8 MHz 
40-pin DIP 

Z0868108CMB 



Z8MCU,4KROM,12MHz 
28-pin DIP 

Z86C1012PSC 



Z8MCU,8KROM,12MHz 
28-pin DIP 

Z86C2012PSO 



Z0869116PSC 



Z0869116VSC 
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Codes 

PACKAGE 

Preferred 

D = Cerdip 

P = Plastic 

V ^ Plastic Chip Carrier 

Longer Lead Time 

C = Ceramic 

F s= Plastic Quad Flat Pack 

G = Ceramic PGA (Pin Grid Array) 

L « Ceramic LCC 

Q s Ceramic Quad-in-Line 

R = Protopack 

T = Low Profile Protopack 

TEMPERATURE 

Preferred 

S = 0*»Cto+70*»C 

Longer Lead Time 
E = -40^Cto+85°C 
M = -55^Cto+125*»C 



ENVIRONMENTAL 

Preferred 

C = Plastic Standard 

E = Hermetic Standard 

F s Protopack Standard 

Longer Lead Time 
A = Hermetic Stressed 
B s 833 Class B Military 
D » Plastic Stressed 
J »JAN 38510 Military 



Example: 

Z0869112PSC is a 12 MHz 8691 (ROMIess Z8) In a plastc DIP, 0^ C to +70° C. Standard 

Flow. 

Z 08691 12 P S C RXXX 

' — ROM Mask Number 

Environmental Flow 

— Temperature 



Speed 

Product Number 
Zilog Prefix 



682 



ZILOG DOMESTIC SALES OFFICES AND 
TECHNICAL CENTERS 



INTERNATIONAL SALES OFFICES 



CALIFORNIA 

Agoura 

Campbell 



COLORADO 



FLORIDA 



GEORGIA 

Nuf cross 

ILLINOIS 



CANADA 

818-707-2160 loronio 

. 408-370-8 1?0 
.714-838-7800 GERMANY 



.303 494-2^)05 JAPAN 
lokyo 

813 58b-?h33 HONGKONG 
Kowlooii 

404-923-8500 KOREA 



312!>17 80W.) SINGAPORE 



.416-673 0634 



.49-89-672-045 



81 3-587-0528 



852-3-723-8979 



.82-2-552 !>401 



NEW HAMPSHIRE 



MINNESOTA 



NEW JERSEY 

Clark 



603 888 851K} TAIWAN 



201 382-57(X) 



UNITED KINGDOM 

Mai(l(MilH»a(J 



886-2/41 3125 



PENNSYLVANIA 



?16 447 14Ji0 



215 653-0230 




^ irwio K., /,(„,, 1,.^ A^ii ^jghts reserved No part of this publica 

.,„, f..,..^^ d, stored in a retrieval system, or transmit 

ted. in any form or by any fneans. electronic, mechanical. 
phr)tocopyiny, reccxding, or otherwise, without the prior written 
permission of Zilog 

The inforrnatir>n contained herein is subject to change without 
notice /ilog assumes no responsibility for the useof any circuitry 
embodied in a Zilog product. No other circuit patent licenses are 
implied 

All specifications (parameters) are subject to change without 
notice. The applicable Zilog test documentation will specify 
which parameters are tested. 
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